TestNG是一个强大的测试框架,这篇文章主要简单说明一下使用TestNG并生成一个简单报告
SureFire插件
开始之前,我们先Maven介绍SureFIre插件(如果你还不了解Maven,请查看之前写的文章小白学Maven笔记 1——快速开始,这个插件使用来在test阶段来实行单元测试的,我们主要用它来生成报告。他可以生成两种格式的报告
- *.txt
- .xml (默认会生成类似于${basedir}/target/surefire-reports/Test-.xml的文件)
1.首先我们在pom.xml文件添加surefire插件和加入testNG框架的依赖
<dependencies>
<dependency>
<groupId>org.testng</groupId>
<artifactId>testng</artifactId>
<version>6.9.8</version>
<scope>test</scope>
</dependency>
</dependencies>
<build>
<pluginManagement>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>2.20</version>
</plugin>
</plugins>
</pluginManagement>
</build>
2.在src/main/java下面创建demo类
package com.moke;
/**
* Created by moke on 2017/4/21.
*/
public class demo {
public String returnString() {
return "test";
}
}
3.在src/test/java下面创建测试类demoTest(这里要以Test结尾,默认只会识别Test结尾的文件,但是可以根据自己需要指定,这里就不多说了)
package com.moke.test;
import com.moke.demo;
import org.testng.Assert;
import org.testng.annotations.Test;
/**
* Created by moke on 2017/4/21.
*/
public class demoTest {
@Test
public void testReturnString() {//这里检验了是否返回test字符串
Assert.assertEquals("test", new demo().returnString());
}
}
4.命令行下执行mvn test,这里可以看到执行成功了一个测试
[INFO] Running com.moke.test.demoTest
[INFO] Tests run: 1, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 0.37 s - in com.moke.test.demoTest
[INFO]
[INFO] Results:
[INFO]
[INFO] Tests run: 1, Failures: 0, Errors: 0, Skipped: 0
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] BUILD SUCCESS
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 3.395 s
[INFO] Finished at: 2017-04-22T23:16:26+08:00
[INFO] Final Memory: 21M/300M
[INFO] ------------------------------------------------------------------------
同时生成的target目录下面我们也能看到surefire-reports目录,这里有surefire插件生成的报告
到目前为止你已经使用TestNG完成了一个简单的测试并且生成了一份报告,接下来我们具体讲解一下TestNG框架
生命周期
我们在src/test/java目录下面创建另外一个文件吧
package com.moke.test;
import org.testng.Assert;
import org.testng.annotations.*;
/**
* Created by moke on 2017/4/20.
*/
public class TestLifeCircle {
@BeforeSuite
public void beforSuite() {
System.out.println("我是beforesuit在整个suit之前只会运行一次");
}
@AfterSuite
public void afterSuit() {
System.out.println("我是aftersuit在整个suit之后只会运行一次");
}
@BeforeTest
public void beforeTest() {
System.out.println("我是beforeTest,在所有<test>标签中类的所有方法运行之前运行一次");
}
@AfterTest
public void afterTest() {
System.out.println("我是afterTest,,在所有<test>标签中类的所有方法运行之后运行一次");
}
@BeforeClass
public void beforeClass() {
System.out.println("我是beforeCLass,在当前class中第一个方法运行前运行一次");
}
@AfterClass
public void afterClass() {
System.out.println("我是afterCLass,在当前class中所有方法运行后运行一次");
}
@BeforeMethod
public void beforeMethod() {
System.out.println("我是beforemethod,在每个测试方法前运行一次");
}
@AfterMethod
public void afterMethod() {
System.out.println("我是aftermethod,在每个测试方法后运行一次");
}
@Test
public void testEmailGenerator() {
System.out.println("testEmailGenerator");
}
@Test
public void testStringGenerator() {
System.out.println("testStringGenerator");
}
}
看到这里,熟悉Junit的朋友应该已经知道什么情况了吧,我们运行一下可以看到类似下面的输出
我是beforesuit在整个suit之前只会运行一次
我是beforeTest,在所有<test>标签中类的所有方法运行之前运行一次
我是beforeCLass,在当前class中第一个方法运行前运行一次
我是beforemethod,在每个测试方法前运行一次
testEmailGenerator
我是aftermethod,在每个测试方法后运行一次
我是beforemethod,在每个测试方法前运行一次
testStringGenerator
我是aftermethod,在每个测试方法后运行一次
我是afterCLass,在当前class中所有方法运行后运行一次
我是afterTest,,在所有<test>标签中类的所有方法运行之后运行一次
我是aftersuit在整个suit之后只会运行一次
刚刚发生了什么?TestNG使用Annotation的方式来指定了一些生命周期,在这些阶段我们可以做各自需要的一些操作,例如每个测试方法必须使用@Test来标记。看了上面的例子相信TestNG的生命周期你应该有一定了解了吧,关于TestNG中的Annotation更多的可以点击TestNG
关于TestNG的其他知识以后有空了在慢慢整理