TestNG - dataprovider

TestNG的Test注解提供了一个参数dataProvider,可以满足我们给测试用例提供个性化的数据格式,使用方法

//1.实现一个返回测试数据的方法,添加@DataProvider注解,并命名name;此方法可以实现多个,按照name进行区分 返回的数据类型也可以为Iterator<Object[]>
@DataProvider(name = "test1")
public Object[][] createData1() {
 return new Object[][] {
   { "Cedric", new Integer(36), "hh"},
   { "Anne", new Integer(37), "aa"},
 };
}
 
//2.在要使用此测试用例的方法上使用dataProvider的names属性进行关联
@Test(dataProvider = "test1")
public void verifyData1(String n1, Integer n2, String n3) {
 System.out.println(n1 + " " + n2 + " " + n3);
}

//打印结果
Cedric 36 hh
Anne 37 aa

为了方便管理测试数据,@DataProvider注解的方法可以单独写到一个类中,使用时通过添加类名进行匹配。实现测试数据方法的类需要有一个显性的没有参数的构造方法,或者测试数据方法使用静态方法

public class StaticProvider {
  @DataProvider(name = "create")
  public static Object[][] createData() {
    return new Object[][] {
      new Object[] { new Integer(42) }
    };
  }
}

//dataProvider的属性值是使用的数据构造方法的DataProvider注解的name值
public class MyTest {
  @Test(dataProvider = "create", dataProviderClass = StaticProvider.class)
  public void test(Integer n) {
    // ...
  }
}

定义DataProvider的第一个参数为Method,可以获取到使用这个方法的单测的方法名。可以帮助我们实现多个方法均调用同一个DataProvider方法,并根据方法名返回不同的内容。可以将数据单独维护,然后根据获取到的类名,方法名去找到对应的数据

public class MyDataProvider {
    @DataProvider(name = "dp")
    public static Object[][] createData(Method m) {
      System.out.println(m.getDeclaringClass().getName()); //print test class name
        System.out.println(m.getName());  // print test method name
        return new Object[][] { new Object[] { "Cedric" }};
    }

}

public class TestNGTest {

    @Test(dataProvider = "dp", dataProviderClass = MyDataProvider.class)
    public void verifyData1(String n1) {
        System.out.println(n1);
    }

    @Test(dataProvider = "dp", dataProviderClass = MyDataProvider.class)
    public void verifyData2(String n1) {
        System.out.println(n1);
    }
}


版权声明:本文为Clever99原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。