工做中一直用的是junit,近期稍微學習了一下TestNg,發現TestNg比java強大太多。java
TestNg簡介數組
TestNg也是一套測試框架,它的靈感來源於Junit(java的單元測試框架)和Nunit(.net的單元測試框架)。可是它又在此基礎上引入了新的東西,使得它更增強大。框架
TestNg表示下一代(next genaration),它不只能夠作單元測試,還能夠作集成測試eclipse
安裝eclipse插件:ide
在eclipse- Help-Install new SoftWare-Add 輸入連接http://beust.com/eclipse/ 一路next便可函數
TestNg優於Junit的地方:單元測試
1.容許分組測試學習
@Test(groups="group1")測試
public void groupTest(){ui
}
而後在testng.xml中定義要包含哪些group,不包含哪些group
2.TestNg容許只運行失敗的例子
執行完testng後,會在test-output目錄下生成一些測試結果文件。若是這次測試有失敗的例子,咱們調試完,想再運行一下這些失敗的例子時,能夠運行testng-failed.xml文件。這個文件就是記錄了上一次全部執行失敗的例子。是否是很方便啊。
3.TestNg容許依賴測試(相似於ant的依賴):
可依賴測試方法:
@Test(dependsOnMethods = { "test2" })
public void test1() {
}
@Test
public void test2() {
}
也可依賴羣組:
@Test(groups = { "init.1" })
public void test1() {
}
@Test(groups = { "init.2" })
public void test2() {
}
@Test(dependsOnGroups = { "init.*" })
public void test2() {
}
4.TestNg支持並行測試(支持測試方法(methods),測試類(classes),小的測試套件(tests),能夠大大提升測試效率
在testng.xml文件中定義線程的個數:
<suite name="Test-class Suite" parallel="classes" thread-count="2" >
<test name="Test-class test" >
<classes>
<class name="class1" />
<class name="class2" />
</classes>
</test>
</suite>
則開了兩個線程一個運行class1,一個運行class2。
5.標籤比junit豐富:
注:testNg中@BeforeTest針對的不是被@Test標記的方法,而是在testNg.xml中定義的test
@BeforeMethod纔是針對的被@Test標記的方法,和junit中@BeforeTest是同一用法。
6.testng被@BeforeClass 和@AfterClass註釋的方法能夠不寫成static方法
7.被@Test標記的方法能夠有輸入參數,而在junit中是不行的
import org.testng.annotations.Parameters;
import org.testng.annotations.Test;
public class ParameterizedTest1 {
@Test
@Parameters("myName")
public void parameterTest(String myName) {
System.out.println("Parameterized value is : " + myName);
}
}
在testng.xml文件中定義參數的值
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE suite SYSTEM "http://testng.org/testng-1.0.dtd" >
<suite name="Suite1">
<test name="test1">
<parameter name="myName" value="qiuqiu"/>
<classes>
<class name="ParameterizedTest1" />
</classes>
</test>
</suite>
可在<suite>標籤或<test>標籤下聲明瞭參數。若是兩個參數同名,在<test>標籤下定義的參數優先
8.testNg能夠經過標註的方式來順序執行
@Test(priority=0)
priority爲0,1,2,3這樣定義,而後就會按照數字從小到大那樣依次執行
相同點:
1.均可以作忽略測試,能夠忽略某個測試方法(在方法上面註釋),也能夠忽略某個測試類(在類的上面註釋)
testNg:
@Test(enabled = false)
Junit:
@Ingore
@Test
2.都支持數據驅動測試,只是用法不同
testng中能夠用@DataProvider,參數化是在測試級別的,不須要經過構造函數來傳遞參數,它會自動映射。
舉例:
//表示這個方法將提供數據給任何聲明它的data provider名爲「test1」的測試方法中
@DataProvider(name = "test1")
public Object[][] createData1() {
return new Object[][] {
{ "Cedric", new Integer(36) },
{ "Anne", new Integer(37)},
};
}
//下面這個方法將要調用名爲test1的data provider提供的數據
@Test(dataProvider="test1")
public void verifyDta(String n1,Integer n2){
System.out.println(n1 + " " + n2);
}
須要注意的是@Test(dataProvider=)和@DataProvider(name=)能夠在同一個類中,使用方法就如上;若是不在同一個類中,那麼必須把@DataProvider(name=)所在的類的這個方法定義成static靜態方法。
而且在@Test使用的時候須要制定類。用法就是@Test(dataProvider="",dataProviderClass=(@DataProvider所在的類).class)
而在junit中就麻煩多了。junit中的參數化是在類級別的,須要經過構造函數來傳遞參數。
以下:
package demo;
public class Try {
public int result=3;
public int add(int n) {
result += n;
return result;
}
}
測試代碼:
package demo;
import static org.junit.Assert.assertEquals;
import java.util.Arrays;
import java.util.Collection;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
import org.junit.runners.Parameterized.Parameters;
//步驟1.指定特殊的運行器Parameterized.class
@RunWith(Parameterized.class)
public class TryTest {
// 步驟2:爲測試類聲明幾個變量,分別用於存放指望值和測試所用數據。此處我只放了測試全部數據,沒放指望值。
private int param, result;
// 步驟3:申明構造函數
public TryTest(int param, int result) {
super();
this.param = param;
this.result = result;
}
// 步驟4:定義測試數據的集合,該方法能夠任意命名
// 可是必須使用@Parameters標註進行修飾
// 這個方法的框架就不予解釋了,你們只須要注意其中的數據,是一個二維數組,數據兩兩一組
// 每組中的這兩個數據,一個是參數,一個是你預期的結果。
// 好比咱們的第一組{4, 7},4就是參數,7就是預期的結果。分別對應上面構造函數的param和result
@Parameters
public static Collection<Object[]> testDate() {
Object[][] object = { { 1, 4 }, { 3, 6 }, { 1, 3 } };
return Arrays.asList(object);
}
// 步驟5:編寫測試方法,使用定義的變量做爲參數進行測試
// 這裏的編寫方法和之前的測試方法同樣
@Test
public void testAdd() {
Try test = new Try();
assertEquals(result, test.add(param));
}
}
3.超時測試,就是在規定時間內若是沒有測試完成,就認定測試失敗
@Test(timeout=100)
4.異常測試,就是在運行這個單元測試的時候應該要捕獲到指定的異常,纔算測試成功補充testng和junit的區別:testng中子類不會運行父類中的@BeforeClass和@AfterClass而在junit中會先運行父類的@BeforeClass,再運行本身的@BeforeClass;而@AfterClass是先運行本身的,再運行父類