TestNG是一個強大的測試框架,這篇文章主要簡單說明一下使用TestNG并生成一個簡單報告
SureFire插件
開始之前,我們先Maven介紹SureFIre插件(如果你還不了解Maven,請查看之前寫的文章小白學(xué)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下面創(chuàng)建demo類
package com.moke;
/**
* Created by moke on 2017/4/21.
*/
public class demo {
public String returnString() {
return "test";
}
}
3.在src/test/java下面創(chuàng)建測試類demoTest(這里要以Test結(jié)尾,默認只會識別Test結(jié)尾的文件,但是可以根據(jù)自己需要指定,這里就不多說了)
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.命令行下執(zhí)行mvn test,這里可以看到執(zhí)行成功了一個測試
[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插件生成的報告


到目前為止你已經(jīng)使用TestNG完成了一個簡單的測試并且生成了一份報告,接下來我們具體講解一下TestNG框架
生命周期
我們在src/test/java目錄下面創(chuàng)建另外一個文件吧
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,在當(dāng)前class中第一個方法運行前運行一次");
}
@AfterClass
public void afterClass() {
System.out.println("我是afterCLass,在當(dāng)前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的朋友應(yīng)該已經(jīng)知道什么情況了吧,我們運行一下可以看到類似下面的輸出
我是beforesuit在整個suit之前只會運行一次
我是beforeTest,在所有<test>標簽中類的所有方法運行之前運行一次
我是beforeCLass,在當(dāng)前class中第一個方法運行前運行一次
我是beforemethod,在每個測試方法前運行一次
testEmailGenerator
我是aftermethod,在每個測試方法后運行一次
我是beforemethod,在每個測試方法前運行一次
testStringGenerator
我是aftermethod,在每個測試方法后運行一次
我是afterCLass,在當(dāng)前class中所有方法運行后運行一次
我是afterTest,,在所有<test>標簽中類的所有方法運行之后運行一次
我是aftersuit在整個suit之后只會運行一次
剛剛發(fā)生了什么?TestNG使用Annotation的方式來指定了一些生命周期,在這些階段我們可以做各自需要的一些操作,例如每個測試方法必須使用@Test來標記??戳松厦娴睦酉嘈臫estNG的生命周期你應(yīng)該有一定了解了吧,關(guān)于TestNG中的Annotation更多的可以點擊TestNG
關(guān)于TestNG的其他知識以后有空了在慢慢整理