Testng 简明教程

TestNG - Parameterized Test

TestNG 中另一项有趣的功能是 parametric testing 。大多数情况下,您会遇到需要大量测试的业务逻辑的情况。 Parameterized tests 允许开发人员使用不同的值反复运行同一测试。

TestNG 让您通过两种不同方式直接将参数传给测试方法 -

  1. With testng.xml

  2. With Data Providers

Passing Parameters with testng.xml

使用这种方法,您可以在 testng.xml 文件中定义简单参数,然后在源文件中引用这些参数。我们举一个示例来说明如何使用这种方法传递参数。

Create Test Case Class

  1. 创建一个 java 测试类,例如,ParameterizedTest1.java。

  2. 向测试类添加 test method parameterTest()。此方法以一个字符串作为输入参数。

  3. 向此方法添加注释 @Parameters("myName")。该参数将从 testng.xml 传递一个值,我们将在下一步中看到。

/work/testng/src 中创建名为 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

/work/testng/src 中创建 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>

我们还可以在 <suite> 级别定义参数。假设我们在 <suite> 和 <test> 级别都定义了 myName。在这种情况下,常规范围规则适用。这意味着 <test> 标签内的任何类都会看到 <test> 中定义的参数值,而 testng.xml 文件中的其余类将看到 <suite> 中定义的值。

使用 javac 编译测试用例类。

/work/testng/src$ javac ParameterizedTest1.java

现在,运行 testng.xml,该文件将运行 parameterTest 方法。TestNG 将尝试首先在 <test> 标签中查找名为 myName 的参数,如果找不到,它将在包含它的 <suit> 标签中搜索。

/work/testng/src$ java org.testng.TestNG testng.xml

验证输出。

Parameterized value is : manisha

===============================================
Suite1
Total tests run: 1, Failures: 0, Skips: 0
===============================================

TestNG 会自动尝试将 testng.xml 中指定的值转换为参数的类型。以下为支持的类型 -

  1. String

  2. int/Integer

  3. boolean/Boolean

  4. byte/Byte

  5. char/Character

  6. double/Double

  7. float/Float

  8. long/Long

  9. short/Short

Passing Parameters with Dataproviders

当您需要传递复杂参数或需要通过 Java 创建的参数(复杂对象、从属性文件或数据库读取的对象等)时,可以使用数据提供器传递参数。

数据提供器是一个用 @DataProvider 注释的方法。此注释只有一个字符串属性:其名称。如果未提供名称,则数据提供程序的名称自动默认为方法的名称。数据提供程序返回一个对象数组。

以下示例演示了如何使用数据提供程序。第一个示例是关于将 Vector、String 或 Integer 作为参数使用 @DataProvider 的,第二个示例是关于将对象作为参数使用 @DataProvider 的。

Example 1

在这里,@DataProvider 将 Integer 和 Boolean 作为参数传递。

Create Java class

创建名为 PrimeNumberChecker.java 的 Java 类。此类检查该数字是否是质数。在 /work/testng/src 中创建此类。

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

  1. /work/testng/src 中创建 Java 测试类,例如 ParamTestWithDataProvider1.java

  2. 定义方法 primeNumbers(),它被定义为使用注解的数据提供者。此方法返回一个对象数组。

  3. 将测试方法 testPrimeNumberChecker() 添加到你的测试类中。此方法接受一个整数和一个布尔值作为输入参数。此方法验证传递的参数是否为素数。

  4. 将注解 @Test(dataProvider = "test1") 添加到此方法。属性 dataProvider 映射到“test1”。

以下为 ParamTestWithDataProvider1.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

创建 /work/testng/src 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 = "ParamTestWithDataProvider1" />
      </classes>
   </test>
</suite>

使用 javac 编译测试用例类。

/work/testng/src$ javac ParamTestWithDataProvider1.java PrimeNumberChecker.java

现在,运行 testng.xml。

/work/testng/src$ java org.testng.TestNG testng.xml

验证输出。

   2 true
   6 false
   19 true
   22 false
   23 true

===============================================
   Suite1
   Total tests run: 5, Failures: 0, Skips: 0
===============================================

Example 2

此处,@DataProvider 将对象作为参数传递。

Create Java class

/work/testng/src 中创建 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

  1. 创建一个 java 测试类,例如 ParamTestWithDataProvider2.java。

  2. 定义方法 primeNumbers(),它被定义为使用注解的数据提供者。此方法返回一个对象数组。

  3. 将测试方法 testMethod() 添加到你的测试类中。此方法接受一个对象 bean 作为参数。

  4. 将注解 @Test(dataProvider = "test1") 添加到此方法。属性 dataProvider 映射到“test1”。

/work/testng/src 中创建名为 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

/work/testng/src 中创建 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 编译测试用例类。

/work/testng/src$ javac ParamTestWithDataProvider2.java Bean.java

现在,运行 testng.xml。

/work/testng/src$ java org.testng.TestNG testng.xml

验证输出。

   hi I am the bean 111

===============================================
   Suite1
   Total tests run: 1, Failures: 0, Skips: 0
===============================================