小组测试(Group Test)
组测试是TestNG中的一项新的创新功能,在JUnit框架中不存在。 它允许您将方法分配到适当的部分并执行复杂的测试方法分组。
您不仅可以声明属于组的方法,还可以指定包含其他组的组。 然后,可以调用TestNG并要求其包含一组特定的组(或正则表达式),同时排除另一组。
组测试为您的测试分区提供了最大的灵活性,如果您想要连续运行两组不同的测试,则不需要重新编译任何内容。
使用标记在testng.xml文件中指定组。 它可以在或标签下找到。 标记中指定的组适用于下面的所有标记。
现在,让我们举一个例子来看看组测试是如何工作的。
创建一个类 (Create a Class)
在C:\》 TestNG_WORKSPACE创建一个要测试的java类,比如MessageUtil.java 。
/*
* 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 "xnip" to the message
public String salutationMessage() {
message = "xnip" + message;
System.out.println(message);
return message;
}
// add "www." to the message
public String exitMessage() {
message = "www." + message;
System.out.println(message);
return message;
}
}
创建测试用例类 (Create Test Case Class)
创建一个java测试类,比如GroupTestExample.java。
将测试方法testPrintMessage()和testSalutationMessage()添加到测试类中。
将测试方法分为两类 -
Check-in tests (checkintest) - 应在提交新代码之前运行这些测试。 它们通常应该很快并确保没有基本功能被破坏。
Functional tests (functest) - 这些测试应该涵盖您软件的所有功能,并且每天至少运行一次,尽管理想情况下您希望连续运行它们。
在C:\》TestNG_WORKSPACE创建名为GroupTestExample.java的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 = "xnip" + ".com";
Assert.assertEquals(message, messageUtil.salutationMessage());
}
@Test(groups = { "functest" })
public void testingExitMessage() {
System.out.println("Inside testExitMessage()");
message = "www." + "xnip"+".com";
Assert.assertEquals(message, messageUtil.exitMessage());
}
}
Create testng.xml
在C:\》 TestNG_WORKSPACE创建testng.xml,以执行测试用例。 在这里,我们将只执行那些属于functest组的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,测试用例类。
C:\TestNG_WORKSPACE>javac MessageUtil.java GroupTestExample.java
现在,运行testng.xml,它将只运行testPrintMessage()方法,因为它属于组functest 。
C:\TestNG_WORKSPACE>java -cp "C:\TestNG_WORKSPACE" 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()
xnip.cn
Inside testExitMessage()
www.xnip.cn
===============================================
Suite1
Total tests run: 3, Failures: 0, Skips: 0
===============================================
排除组
您可以使用标记忽略组,如下所示 -
<?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>