TestNG - 依赖测试

  • 简述

    有时,您可能需要以特定顺序调用测试用例中的方法,或者您可能希望在方法之间共享一些数据和状态。TestNG 支持这种依赖关系,因为它支持测试方法之间显式依赖关系的声明。
    TestNG 允许您指定依赖项 -
    • 在@Test 注释中使用属性dependsOnMethods,或者。
    • 在@Test 注释中使用属性dependsOnGroups
  • 使用dependsOnMethods 的示例

    创建一个类

    创建一个要测试的java类,比如说, MessageUtil.java/work/testng/src.
    
    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;
       }
    }
    

    创建测试用例类

    • 创建一个java测试类,比如DependencyTestUsingAnnotation.java /work/testng/src.
    • 将测试方法 testPrintMessage() 和 testSalutationMessage() 以及 initEnvironmentTest() 添加到您的测试类。
    • 添加属性 dependsOnMethods = {"initEnvironmentTest"} 到@Test注解 testSalutationMessage() 方法。
    以下是 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");
       }
    }
    

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

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

    创建一个类

    创建一个要测试的java类,比如说, MessageUtil.java/work/testng/src.
    
    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;
       }
    }
    

    创建测试用例类

    • 创建一个 java 测试类,比如 DependencyTestUsingAnnotation.java。
    • 将测试方法、testPrintMessage()、testSalutationMessage() 和 initEnvironmentTest() 添加到您的测试类,并将它们添加到“init”组中。
    • 添加属性 dependsOnMethods = {"init.*"} 到@Test注解 testSalutationMessage() 方法。
    创建一个名为的java类文件 DependencyTestUsingAnnotation.java/work/testng/src.
    
    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.*”,这保证方法 testPrintMessage() 和 initEnvironmentTest() 将始终在 testSalutationMessage() 之前被调用。
    如果依赖的方法失败,并且您对它有硬依赖(alwaysRun=false,这是默认值),则依赖它的方法不会标记为 FAIL,而是标记为 SKIP。跳过的方法将在最终报告中这样报告(在 HTML 中,颜色既不是红色也不是绿色),这很重要,因为跳过的方法不一定是失败的。

    创建 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 = "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 或groups 属性,我们的测试就会在正确的依赖项设置下继续运行。
    • 每当需要在依赖图中添加新方法时,我们所需要做的就是将其放入正确的组中并确保它依赖于正确的组。我们不需要修改任何其他方法。