TestNG虽然是从Junit继承而来,但同时引入的新功能使其更为强大,更容易使用:
- Annotations注释, 如 @test @BeforeMethod @BeforeClass
- 有多种可行方案来在任意大的线程池内运行case(所有方法在他们自己的线程,一个线程一个测试类,等等)
- 测试是多线程安全的
- 灵活的测试配置(可通过testing.xml来管理执行case和suite)
- 支持数据驱动测试(@DataProvider)
- 支持参数
- 强大的执行模型
- 有一系列的工具和插件支持(Eclipse,IDEA,Maven,Ant,etc...)
- 为了进一步的灵活性可潜入BeanShell
- 默认JDK函数运行和日志记录(无依赖关系)
- 依赖应用服务器测试的方法
- 能够配合reporting生成客观的测试报告
TestNG常用的基本注解
注解 | 描述 |
---|---|
@BeforeSuite | 注解的方法将只运行一次,运行所有测试前此套件中。 |
@AfterSuite | 注解的方法将只运行一次此套件中的所有测试都运行之后。 |
@BeforeClass | 注解的方法将只运行一次先行先试在当前类中的方法调用。 |
@AfterClass | 注解的方法将只运行一次后已经运行在当前类中的所有测试方法。 |
@BeforeTest | 注解的方法将被运行之前的任何测试方法属于内部类的 <test>标签的运行。 |
@AfterTest | 注解的方法将被运行后,所有的测试方法,属于内部类的<test>标签的运行。 |
@BeforeGroups | 组的列表,这种配置方法将之前运行。此方法是保证在运行属于任何这些组第一个测试方法,该方法被调用。 |
@AfterGroups | 组的名单,这种配置方法后,将运行。此方法是保证运行后不久,最后的测试方法,该方法属于任何这些组被调用。 |
@BeforeMethod | 注解的方法将每个测试方法之前运行。 |
@AfterMethod | 被注释的方法将被运行后,每个测试方法。 |
@DataProvider |
标志着一个方法,提供数据的一个测试方法。注解的方法必须返回一个Object[] [],其中每个对象[]的测试方法的参数列表中可以分配。
该@Test 方法,希望从这个DataProvider的接收数据,需要使用一个dataProvider名称等于这个注解的名字。 |
@Factory | 作为一个工厂,返回TestNG的测试类的对象将被用于标记的方法。该方法必须返回Object[]。 |
@Listeners | 定义一个测试类的监听器。 |
@Parameters | 介绍如何将参数传递给@Test方法。 |
@Test | 标记一个类或方法作为测试的一部分。 |
TestNG的基本使用
先点击下载 TestNG-6.9.10.jar 并导入到项目中。
package example1;
import org.testng.annotations.*;
public class SimpleTest {
@BeforeClass
public void setUp() {
// code that will be invoked when this test is instantiated
System . out . println ( "start" );
}
@Test
public void test() {
System.out.println("test");
}
@AfterClass
public void end() {
// code that will be invoked after test
System . out . println ( "end" );
}
}
用Eclipse执行结果: