SureFire插件
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的生命周期你应该有一定了解了吧。