TestNG - 组测试
-
简述
组测试是TestNG 中一个新的创新特性,它在JUnit 框架中是不存在的。它允许您将方法分派到适当的部分并执行复杂的测试方法分组。您不仅可以声明属于组的那些方法,还可以指定包含其他组的组。然后,可以调用 TestNG 并要求它包含一组特定的组(或正则表达式),同时排除另一组。组测试在如何划分测试方面提供了最大的灵活性,并且如果您想背靠背运行两组不同的测试,则不需要重新编译任何内容。使用 <groups> 标记在 testng.xml 文件中指定组。它可以在 <test> 或 <suite> 标签下找到。<suite> 标记中指定的组适用于下面的所有 <test> 标记。现在,让我们举一个例子来看看组测试是如何工作的。 -
创建一个类
-
创建一个要测试的java类,比如说, MessageUtil.java 在 /work/testng/src.
/* * This class prints the given message on console. */ 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 "jc2182" to the message public String salutationMessage() { message = "jc2182" + message; System.out.println(message); return message; } // add "www." to the message public String exitMessage() { message = "www." + message; System.out.println(message); return message; } }
-
-
创建测试用例类
-
创建一个 java 测试类,比如说, GroupTestExample.java 在 /work/testng/src.
-
将测试方法 testPrintMessage() 和 testSalutationMessage() 添加到您的测试类。
-
将测试方法分为两类 -
-
Check-in tests (checkintest)- 这些测试应该在您提交新代码之前运行。它们通常应该很快,并且确保没有基本功能被破坏。
-
Functional tests (functest) − 这些测试应涵盖您软件的所有功能,并且每天至少运行一次,尽管理想情况下您希望连续运行它们。
-
以下是内容 GroupTestExample.java.import org.testng.Assert; import org.testng.annotations.Test; public class GroupTestExample { String message = ".com"; MessageUtil messageUtil = new MessageUtil(message); @Test(groups = { "functest", "checkintest" }) public void testPrintMessage() { System.out.println("Inside testPrintMessage()"); message = ".com"; Assert.assertEquals(message, messageUtil.printMessage()); } @Test(groups = { "checkintest" }) public void testSalutationMessage() { System.out.println("Inside testSalutationMessage()"); message = "jc2182" + ".com"; Assert.assertEquals(message, messageUtil.salutationMessage()); } @Test(groups = { "functest" }) public void testingExitMessage() { System.out.println("Inside testExitMessage()"); message = "www." + "jc2182"+".com"; Assert.assertEquals(message, messageUtil.exitMessage()); } }
-
-
创建 testng.xml
在中创建 testng.xml /work/testng/src, 执行测试用例。在这里,我们将只执行那些属于functest组的测试。<?xml version = "1.0" encoding = "UTF-8"?> <!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" > <suite name = "Suite1"> <test name = "test1"> <groups> <run> <include name = "functest" /> </run> </groups> <classes> <class name = "GroupTestExample" /> </classes> </test> </suite>
使用 javac 编译 MessageUtil、测试用例类。/work/testng/src$ javac MessageUtil.java GroupTestExample.java
现在,运行 testng.xml,它将只运行方法 testPrintMessage(),因为它属于functest组。/work/testng/src$ java org.testng.TestNG testng.xml
验证输出。仅执行方法 testPrintMessage()。Inside testPrintMessage() .com Inside testExitMessage() www..com =============================================== Suite1 Total tests run: 2, Failures: 1, Skips: 0 ===============================================
-
组组
组还可以包括其他组。这些组被称为MetaGroups. 例如,您可能要定义一组所有,其中包括checkintest和functest。让我们修改我们的 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"> <groups> <define name = "all"> <include name = "functest"/> <include name = "checkintest"/> </define> <run> <include name = "all"/> </run> </groups> <classes> <class name = "GroupTestExample" /> </classes> </test> </suite>
执行上面的 testng.xml 将执行所有三个测试,并会给你以下结果 -Inside testPrintMessage() .com Inside testSalutationMessage() cainiaoya.com Inside testExitMessage() www.cainiaoya.com =============================================== Suite1 Total tests run: 3, Failures: 0, Skips: 0 ===============================================
-
排除组
您可以使用 <exclude> 标签忽略组,如下所示 -<?xml version = "1.0" encoding = "UTF-8"?> <!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" > <suite name = "Suite1"> <test name = "test1"> <groups> <define name = "all"> <exclude name = "functest"/> <include name = "checkintest"/> </define> <run> <include name = "all"/> </run> </groups> <classes> <class name = "GroupTestExample" /> </classes> </test> </suite>