|
JUnit测试
TestNG 能够运行 JUnit 测试。所有要做的工作就是在testng.classNames属性中设定要运行的JUnit测试类,并且
把testng.junit属性设置为true:
<test name="Test1" junit="true">
<classes>
<!-- ... -->
TestNG 在这种情况下所表现的行为与 JUnit 相似:
junit3
所有类中要运行的测试方法由 test* 开头
如果类中有 setUp() 方法,则其会在每个测试方法执行前被调用
如果类中有 tearDown() 方法,则其会在每个测试方法之后被调用
如果测试类包含 suite() 方法,则所有的被这个方法返回的测试类都会被调用
junit4
TestNG将使用org.junit.runner.JUnitCore运行器运行测试
程序化运行TestNG
在程序中非常轻松的调用TestNG的测试:
- TestListenerAdapter tla = new TestListenerAdapter();
- TestNG testng = new TestNG();
- testng.setTestClasses(new Class[] { Run2.class });
- testng.addListener(tla);
- testng.run();
复制代码
本例中创建了一个TestNG对象,并且运行测试类Run2。它添加了一个 TestListener(这是个监听器) 。可
以使用适配器类 org.testng.TestListenerAdapter来做,
也可以实现org.testng.ITestListener接口。这个接口包含了各种各样的回调方法,能够跟踪测试什么时候开
始、成功、失败等等
类似的可以用testng.xml文件调用或者创建一个虚拟的testng.xml文件来调用。为此,可以使用这个包org.
testng.xml中的类:XmlClass、XmlTest等等。每个类都对应了其在xml中对等的标签
例如,假设要创建下面这样的虚拟文件:
- <suite name="TmpSuite" >
- <test name="TmpTest" >
- <classes>
- <class name="test.failures.Child" />
- <classes>
- </test>
- </suite>
- 需要使用如下代码:
- XmlSuite suite = new XmlSuite();
- suite.setName("TmpSuite");
- XmlTest test = new XmlTest(suite);
- test.setName("TmpTest");
- List<XmlClass> classes = new ArrayList<XmlClass>();
- classes.add(new XmlClass("test.failures.Child"));
- test.setXmlClasses(classes) ;
- 之后可以传递这个XmlSuite给 TestNG:
- List<XmlSuite> suites = new ArrayList<XmlSuite>();
- suites.add(suite);
- TestNG tng = new TestNG();
- tng.setXmlSuites(suites);
- tng.run();
复制代码
BeanShell于高级组选择
如果<include>和<exclude>不够用,那就是用BeanShell表达式来决定是否一个特定的测试方法应该被包含
进来。只要在<test>标签下使用这个表达式就好了:
- <test name="BeanShell test">
- <method-selectors>
- <method-selector>
- <script language="beanshell"><![CDATA[
- groups.containsKey("test1")
- ]]></script>
- </method-selector>
- </method-selectors>
- <!-- ... -->
复制代码
当在testng.xml文件中找到<script>标签后,TestNG 就会忽略在当前<test>标签内组和方法的的<include>和
<exclude>标签:BeanShell就会成为测试方法是否被包含的唯一决定因素。
BeanShell 脚本的额外说明:
必须返回一个boolean值。除了这个约束以外,任何有效的BeanShell代码都是允许的 (例如,可能需要在工作
日返回true而在周末返回false,这样就允许你可以依照不同的日期进行测试)。
TestNG 定义了如下的变量供你调用:
java.lang.reflect.Method method: 当前的测试方法
org.testng.ITestNGMethod testngMethod: 当前测试方法的描述
java.util.Map<String, String> groups: 当前测试方法所属组的映射
也可以使用 CDATA 声明来括起Beanshell表达式(就像上例)来避免对XML保留字冗长的引用
TestNG 监听器
有很多接口可以用来修改 TestNG 的行为。这些接口都被统称为 "TestNG 监听器"。
下面是目前支持的监听器的列表:
IAnnotationTransformer (doc, javadoc)
IReporter (doc, javadoc)
ITestListener (doc, javadoc)
IMethodInterceptor (doc, javadoc)
IInvokedMethodListener (doc, javadoc)
当实现了这些接口,你可以让 TestNG 知道这些接口,有如下方式:
在命令行下使用 -listener
ant中使用<listeners>
在testng.xml中使用<listeners>标签
在测试类上述用@Listeners注释
使用ServiceLoader
|
|