MilgGtery 发表于 2018-4-24 16:59:18

TestNG 的JUnit测试和监听器

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



页: [1]
查看完整版本: TestNG 的JUnit测试和监听器