小白学TestNG笔记|小白学TestNG笔记 1——简单使用Testng

TestNG是一个强大的测试框架,这篇文章主要简单说明一下使用TestNG并生成一个简单报告
SureFire插件 开始之前,我们先Maven介绍SureFIre插件(如果你还不了解Maven,请查看之前写的文章小白学Maven笔记 1——快速开始,这个插件使用来在test阶段来实行单元测试的,我们主要用它来生成报告。他可以生成两种格式的报告

  • *.txt
  • .xml (默认会生成类似于${basedir}/target/surefire-reports/Test-.xml的文件)
1.首先我们在pom.xml文件添加surefire插件和加入testNG框架的依赖
org.testng testng 6.9.8 test org.apache.maven.plugins maven-surefire-plugin 2.20

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笔记 1——简单使用Testng
文章图片
屏幕快照 2017-04-22 23.23.01.png 小白学TestNG笔记|小白学TestNG笔记 1——简单使用Testng
文章图片
屏幕快照 2017-04-22 23.31.39.png 到目前为止你已经使用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,在所有标签中类的所有方法运行之前运行一次"); }@AfterTest public void afterTest() { System.out.println("我是afterTest,,在所有标签中类的所有方法运行之后运行一次"); }@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,在所有标签中类的所有方法运行之前运行一次 我是beforeCLass,在当前class中第一个方法运行前运行一次 我是beforemethod,在每个测试方法前运行一次 testEmailGenerator 我是aftermethod,在每个测试方法后运行一次 我是beforemethod,在每个测试方法前运行一次 testStringGenerator 我是aftermethod,在每个测试方法后运行一次 我是afterCLass,在当前class中所有方法运行后运行一次 我是afterTest,,在所有标签中类的所有方法运行之后运行一次 我是aftersuit在整个suit之后只会运行一次

刚刚发生了什么?TestNG使用Annotation的方式来指定了一些生命周期,在这些阶段我们可以做各自需要的一些操作,例如每个测试方法必须使用@Test来标记。看了上面的例子相信TestNG的生命周期你应该有一定了解了吧,关于TestNG中的Annotation更多的可以点击TestNG
【小白学TestNG笔记|小白学TestNG笔记 1——简单使用Testng】关于TestNG的其他知识以后有空了在慢慢整理

    推荐阅读