- TestNG 教程
- TestNG - 首页
- 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 的示例
创建一个类
创建一个要测试的 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"} 添加到 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 的示例
您还可以拥有依赖于整个组的方法。让我们来看一个示例来说明这一点。
创建一个类
创建一个要测试的 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”。
将属性 dependsOnGroups = {"init"} 添加到 testSalutationMessage() 方法的 @Test 注解中。(原文有误,应为dependsOnGroups, dependsOnMethods 会导致循环依赖)
在 /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 中的颜色既不是红色也不是绿色),这很重要,因为跳过的测试方法不一定是失败的测试方法。
创建 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 与 dependsOnMethods 的比较
使用组时,我们不再会遇到重构问题。只要我们不修改 dependsOnGroups 或 groups 属性,我们的测试就会继续使用正确的依赖关系设置运行。
每当需要在依赖关系图中添加新方法时,我们只需要将其放入正确的组中并确保它依赖于正确的组即可。我们不需要修改任何其他方法。