- 测试NG教程
- 测试NG - 主页
- TestNG - 概述
- TestNG - 环境
- TestNG - 编写测试
- TestNG - 基本注释
- TestNG - 执行过程
- TestNG - 执行测试
- TestNG - 套件测试
- TestNG - 忽略测试
- TestNG - 小组测试
- TestNG - 异常测试
- TestNG - 依赖性测试
- TestNG - 参数化测试
- TestNG - 运行 JUnit 测试
- TestNG - 测试结果
- TestNG - 注释变压器
- TestNG - 断言
- TestNG - 并行执行
- TestNG - 带 ANT 的插头
- TestNG - 使用 Eclipse 进行插件
- TestNG - TestNG - 与 JUnit
- TestNG 有用资源
- TestNG - 快速指南
- TestNG - 有用的资源
- TestNG - 讨论
TestNG - 依赖性测试
有时,您可能需要按特定顺序调用测试用例中的方法,或者您可能希望在方法之间共享一些数据和状态。TestNG 支持这种依赖关系,因为它支持测试方法之间显式依赖关系的声明。
TestNG 允许您使用以下命令指定依赖项:
在@Test注释中使用属性dependsOnMethods,或者。
在@Test注释中使用属性dependsOnGroups 。
使用dependsOnMethods 的示例
创建一个类
在/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; } }
创建测试用例类
在/work/testng/src中创建一个 java 测试类,例如 DependencyTestUsingAnnotation.java 。
将测试方法 testPrintMessage() 和 testSalutationMessage() 以及 initEnvironmentTest() 添加到您的测试类中。
将属性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"); } }
创建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 的示例
您还可以拥有依赖于整个组的方法。让我们举一个例子来证明这一点。
创建一个类
在/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; } }
创建测试用例类
创建一个 java 测试类,例如 DependencyTestUsingAnnotation.java。
将测试方法 testPrintMessage() testSalutationMessage() 和 initEnvironmentTest() 添加到测试类中,并将它们添加到“init”组中。
将属性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.*”,这保证了方法 testPrintMessage() 和 initEnvironmentTest() 将始终在 testSalutationMessage() 之前调用。
如果依赖的方法失败,并且您对其具有硬依赖关系(alwaysRun=false,这是默认值),则依赖于它的方法不会被标记为 FAIL,而是标记为 SKIP。跳过的方法将在最终报告中进行报告(在 HTML 中既不是红色也不是绿色的颜色),这一点很重要,因为跳过的方法不一定是失败。
创建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与dependentOnMethods
在使用组时,我们不再面临重构问题。只要我们不修改 dependentOnGroups 或 groups 属性,我们的测试就会继续运行并设置正确的依赖项。
每当需要在依赖图中添加新方法时,我们所需要做的就是将其放入正确的组中,并确保它依赖于正确的组。我们不需要修改任何其他方法。