参数化测试(Parameterized Test)
TestNG中另一个有趣的功能是parametric testing 。 在大多数情况下,您会遇到业务逻辑需要大量不同测试的情况。 Parameterized tests允许开发人员使用不同的值反复运行相同的测试。
TestNG允许您以两种不同的方式将参数直接传递给您的测试方法 -
- 用testng.xml
- 使用数据提供商
使用testng.xml传递参数
使用此技术,您可以在testng.xml文件中定义简单参数,然后在源文件中引用这些参数。 让我们举个例子来演示如何使用这种技术传递参数。
创建测试用例类
创建一个java测试类,比如,ParameterizedTest1.java。
将测试方法parameterTest()添加到测试类。 此方法将字符串作为输入参数。
将注释@Parameters("myName")添加到此方法。 该参数将从testng.xml传递一个值,我们将在下一步中看到。
在C:\》TestNG_WORKSPACE创建名为ParameterizedTest1.java的java类文件。
import org.testng.annotations.Parameters;
import org.testng.annotations.Test;
public class ParameterizedTest1 {
@Test
@Parameters("myName")
public void parameterTest(String myName) {
System.out.println("Parameterized value is : " + myName);
}
}
Create testng.xml
在C:\》TestNG_WORKSPACE创建testng.xml以执行测试用例。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<parameter name = "myName" value="manisha"/>
<classes>
<class name = "ParameterizedTest1" />
</classes>
</test>
</suite>
我们也可以定义参数 水平。 假设我们已经在“套件”和“测试”级别定义了myName 。 在这种情况下,适用常规范围规则。 这意味着“test”标记内的任何类都将看到“test”中定义的参数值,而testng.xml文件其余部分中的类将看到“suite”中定义的值。
使用javac编译测试用例类。
C:\TestNG_WORKSPACE>javac ParameterizedTest1.java
现在,运行testng.xml,它将运行parameterTest方法。 TestNG将尝试在“test”标记中首先找到名为myName的参数,然后,如果找不到它,则会在包含它的“suit”标记中进行搜索。
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
验证输出。
Parameterized value is : manisha
===============================================
Suite1
Total tests run: 1, Failures: 0, Skips: 0
===============================================
TestNG将自动尝试将testng.xml中指定的值转换为您的参数类型。 以下是支持的类型 -
- String
- int/Integer
- boolean/Boolean
- byte/Byte
- char/Character
- double/Double
- float/Float
- long/Long
- short/Short
使用Dataproviders传递参数
当您需要传递需要从Java创建的复杂参数或参数(复杂对象,从属性文件或数据库读取的对象等)时,可以使用Dataproviders传递参数。
数据提供程序是使用@DataProvider注释的方法。 此批注只有一个字符串属性:名称。 如果未提供名称,则数据提供程序的名称将自动默认为方法的名称。 数据提供程序返回一个对象数组。
以下示例演示了如何使用数据提供程序。 第一个示例是使用Vector,String或Integer作为参数的@DataProvider,第二个示例是使用object作为参数的@DataProvider。
例子1 (Example 1)
这里,@ DataProvider传递Integer和Boolean作为参数。
Create Java class
创建一个名为PrimeNumberChecker.java的java类。 该类检查数字是否为素数。 在C:\》TestNG_WORKSPACE创建此类。
public class PrimeNumberChecker {
public Boolean validate(final Integer primeNumber) {
for (int i = 2; i < (primeNumber/2); i++) {
if (primeNumber % i == 0) {
return false;
}
}
return true;
}
}
Create Test Case Class
创建一个java测试类,比如ParamTestWithDataProvider1.java。
定义方法primeNumbers(),它使用注释定义为数据提供者。 此方法返回一个对象数组。
将测试方法testPrimeNumberChecker()添加到测试类。 此方法将Integer和Boolean作为输入参数。 此方法验证传递的参数是否为素数。
将注释@Test(dataProvider = "test1")添加到此方法。 属性dataProvider映射到“test1”。
在C:\》TestNG_WORKSPACE创建名为ParamTestWithDataProvider1.java的java类文件。
import org.testng.Assert;
import org.testng.annotations.BeforeMethod;
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
public class ParamTestWithDataProvider1 {
private PrimeNumberChecker primeNumberChecker;
@BeforeMethod
public void initialize() {
primeNumberChecker = new PrimeNumberChecker();
}
@DataProvider(name = "test1")
public static Object[][] primeNumbers() {
return new Object[][] {{2, true}, {6, false}, {19, true}, {22, false}, {23, true}};
}
// This test will run 4 times since we have 5 parameters defined
@Test(dataProvider = "test1")
public void testPrimeNumberChecker(Integer inputNumber, Boolean expectedResult) {
System.out.println(inputNumber + " " + expectedResult);
Assert.assertEquals(expectedResult, primeNumberChecker.validate(inputNumber));
}
}
Create testng.xml
创建一个testng.xml C:\》TestNG_WORKSPACE来执行测试用例。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<classes>
<class name = "ParamTestWithDataProvider1" />
</classes>
</test>
</suite>
使用javac编译测试用例类。
C:\TestNG_WORKSPACE>.javac ParamTestWithDataProvider1.java PrimeNumberChecker.java
现在,运行testng.xml。
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
验证输出。
2 true
6 false
19 true
22 false
23 true
===============================================
Suite1
Total tests run: 5, Failures: 0, Skips: 0
===============================================
例子2 (Example 2)
这里,@ DataProvider将Object作为参数传递。
Create Java class
在C:\》TestNG_WORKSPACE创建一个java类Bean.java,它是一个带get/set方法的简单对象。
public class Bean {
private String val;
private int i;
public Bean(String val, int i) {
this.val = val;
this.i = i;
}
public String getVal() {
return val;
}
public void setVal(String val) {
this.val = val;
}
public int getI() {
return i;
}
public void setI(int i) {
this.i = i;
}
}
Create Test Case Class
创建一个java测试类,比如ParamTestWithDataProvider2.java。
定义primeNumbers()方法,该方法使用注释定义为数据提供者。 此方法返回一个对象数组。
将测试方法testMethod()添加到测试类中。 此方法将对象bean作为参数。
将注释@Test(dataProvider = "test1")添加到此方法。 属性dataProvider映射到“test1”。
在C:\》TestNG_WORKSPACE创建名为ParamTestWithDataProvider2.java的java类文件。
import org.testng.annotations.DataProvider;
import org.testng.annotations.Test;
public class ParamTestWithDataProvider2 {
@DataProvider(name = "test1")
public static Object[][] primeNumbers() {
return new Object[][] { { new Bean("hi I am the bean", 111) } };
}
@Test(dataProvider = "test1")
public void testMethod(Bean myBean) {
System.out.println(myBean.getVal() + " " + myBean.getI());
}
}
Create testng.xml
在C:\》TestNG_WORKSPACE创建testng.xml以执行测试用例。
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name = "Suite1">
<test name = "test1">
<classes>
<class name = "ParamTestWithDataProvider2" />
</classes>
</test>
</suite>
使用javac编译测试用例类。
C:\TestNG_WORKSPACE>javac ParamTestWithDataProvider2.java Bean.java
现在,运行testng.xml。
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" org.testng.TestNG testng.xml
验证输出。
hi I am the bean 111
===============================================
Suite1
Total tests run: 1, Failures: 0, Skips: 0
===============================================