Testng 简明教程

TestNG - Dependency Test

有时,您可能需要按照特定顺序在测试用例中调用方法,或者可能希望在方法之间共享某些数据和状态。此类依赖关系受 TestNG 支持,因为它支持在测试方法之间声明显式依赖关系。

TestNG 允许您使用以下方法指定依赖关系:

  1. 在 @Test 注释中使用 dependsOnMethods 特性,或

  2. 在 @Test 注释中使用 dependsOnGroups 特性。

Example Using dependsOnMethods

Create a Class

/work/testng/src 中创建要测试的 java 类,比如 MessageUtil.java

public class MessageUtil {
   private String message;

   // Constructor
   // @param message to be printed
   public MessageUtil(String message) {
      this.message = message;
   }

   // prints the message
   public String printMessage() {
      System.out.println(message);
      return message;
   }

   // add "Hi!" to the message
   public String salutationMessage() {
      message = "Hi!" + message;
      System.out.println(message);
      return message;
   }
}

Create Test Case Class

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

  2. 向您的测试类中添加测试方法 testPrintMessage() 和 testSalutationMessage(),以及 initEnvironmentTest()。

  3. 将特性 dependsOnMethods = {"initEnvironmentTest"} 添加到 testSalutationMessage() 方法的 @Test 注释中。

以下是 DependencyTestUsingAnnotation.java 内容。

import org.testng.Assert;
import org.testng.annotations.Test;

public class DependencyTestUsingAnnotation {
String message = "Manisha";
MessageUtil messageUtil = new MessageUtil(message);

   @Test
   public void testPrintMessage() {
      System.out.println("Inside testPrintMessage()");
      message = "Manisha";
      Assert.assertEquals(message, messageUtil.printMessage());
   }

   @Test(dependsOnMethods = { "initEnvironmentTest" })
   public void testSalutationMessage() {
      System.out.println("Inside testSalutationMessage()");
      message = "Hi!" + "Manisha";
      Assert.assertEquals(message, messageUtil.salutationMessage());
   }

   @Test
   public void initEnvironmentTest() {
      System.out.println("This is initEnvironmentTest");
   }
}

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 = "DependencyTestUsingAnnotation" />
      </classes>
   </test>
</suite>

使用 javac 编译 MessageUtil 和测试用例类。

/work/testng/src$ javac MessageUtil.java DependencyTestUsingAnnotation.java

现在,运行 testng.xml,它将在执行 initEnvironmentTest() 方法后才运行 testSalutationMessage() 方法。

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

验证输出。

This is initEnvironmentTest
Inside testPrintMessage()
Manisha
Inside testSalutationMessage()
Hi!Manisha

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

Example Using dependsOnGroups

您还可以拥有依赖于整个组的方法。我们举一个例子来说明这一点。

Create a Class

/work/testng/src 中创建要测试的 java 类,比如 MessageUtil.java

public class MessageUtil {
   private String message;

   // Constructor
   // @param message to be printed
   public MessageUtil(String message) {
      this.message = message;
   }

   // prints the message
   public String printMessage() {
      System.out.println(message);
      return message;
   }

   // add "Hi!" to the message
   public String salutationMessage() {
      message = "Hi!" + message;
      System.out.println(message);
      return message;
   }
}

Create Test Case Class

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

  2. 向您的测试类中添加测试方法 testPrintMessage() testSalutationMessage(),以及 initEnvironmentTest(),并将它们添加到组“init”中。

  3. 将特性 dependsOnMethods = {"init. "}* 添加到 testSalutationMessage() 方法的 @Test 注释中。

/work/testng/src 中创建名为 DependencyTestUsingAnnotation.java 的 java 类文件。

import org.testng.Assert;
import org.testng.annotations.Test;

public class DependencyTestUsingAnnotation {
   String message = "Manisha";
   MessageUtil messageUtil = new MessageUtil(message);

   @Test(groups = { "init" })
   public void testPrintMessage() {
      System.out.println("Inside testPrintMessage()");
      message = "Manisha";
      Assert.assertEquals(message, messageUtil.printMessage());
   }

   @Test(dependsOnGroups = { "init.*" })
   public void testSalutationMessage() {
      System.out.println("Inside testSalutationMessage()");
      message = "Hi!" + "Manisha";
      Assert.assertEquals(message, messageUtil.salutationMessage());
   }

   @Test(groups = { "init" })
   public void initEnvironmentTest() {
      System.out.println("This is initEnvironmentTest");
   }
}

在此示例中,testSalutationMessage() 被声明为依赖于任何组,匹配正则表达式“init.*”,这可确保总是在 testSalutationMessage() 之前调用方法 testPrintMessage() 和 initEnvironmentTest()。

如果依赖的方法失败,并且您对它有硬依赖关系(alwaysRun=false,这是默认值),那么依赖于它的方法不会标记为 FAIL,而是标记为 SKIP。跳过的方法将在最终报告中报告为这种状态(在 HTML 中既不是红色也不是绿色),这很重要,因为跳过的方法不一定是失败的。

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 = "DependencyTestUsingAnnotation" />
      </classes>
   </test>
</suite>

使用 javac 编译 MessageUtil 和测试用例类。

/work/testng/src$ javac MessageUtil.java DependencyTestUsingAnnotation.java

现在,运行 testng.xml,它将在执行 initEnvironmentTest() 方法后才运行 testSalutationMessage() 方法。

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

验证输出。

This is initEnvironmentTest
Inside testPrintMessage()
Manisha
Inside testSalutationMessage()
Hi!Manisha

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

dependsOnGroups Vs dependsOnMethods

  1. 在使用组时,我们不再会遇到重构问题。只要我们不修改 dependsOnGroups 或 groups 特性,我们的测试就会继续运行,并且正确设置了依赖关系。

  2. 每当需要在依赖关系图中添加新方法时,我们所需要做的就是将其放在正确组中,并确保它依赖于正确的组。我们不需要修改任何其他方法。