TestNG - 参数化测试


TestNG 中另一个有趣的功能是参数测试。在大多数情况下,您会遇到业务逻辑需要大量不同数量的测试的场景。参数化测试允许开发人员使用不同的值一遍又一遍地运行相同的测试。

TestNG 允许您以两种不同的方式将参数直接传递到测试方法 -

  • 使用 testng.xml
  • 与数据提供商

使用testng.xml传递参数

使用此技术,您可以在testng.xml文件中定义简单参数,然后在源文件中引用这些参数。让我们通过一个例子来演示如何使用这种技术来传递参数。

创建测试用例类

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

  • 将测试方法parameterTest() 添加到您的测试类中。该方法接受一个字符串作为输入参数。

  • 将注释@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);
   }
}

创建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 中指定的值转换为参数的类型。以下是支持的类型 -

  • 细绳
  • 整数/整数
  • 布尔值/布尔值
  • 字节/字节
  • 字符/字符
  • 双/双
  • 浮动/浮动
  • 长/长
  • 短/短

与数据提供者传递参数

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

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

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

实施例1

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

创建Java类

创建一个名为 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;
   }
}

创建测试用例类

  • /work/testng/src中创建一个 java 测试类,例如ParamTestWithDataProvider1.java

  • 定义方法 primeNumbers(),使用注释将其定义为数据提供者。该方法返回一个对象数组。

  • 将测试方法 testPrimeNumberChecker() 添加到您的测试类中。该方法采用整数和布尔值作为输入参数。此方法验证传递的参数是否是素数。

  • 在此方法中添加注释@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));
   }
}

创建testng.xml

创建 testng.xml /work/testng/src来执行测试用例。

<?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
===============================================

实施例2

在这里,@DataProvider 将对象作为参数传递。

创建Java类

在/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;
   }
}

创建测试用例类

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

  • 定义方法 primeNumbers(),使用注解将其定义为数据提供者。该方法返回一个对象数组。

  • 将测试方法 testMethod() 添加到您的测试类中。该方法采用对象 bean 作为参数。

  • 在此方法中添加注释@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());
   }
}

创建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
===============================================