TestNG與JUnit的嘴仗似乎告一段落了,Gunjan Doshi今天發(fā)布了一個"JUnit 4.0 in 10 Minutes: A Quick Reference Guide",學習筆記如下。
注:所有代碼和插圖都來自于原文。
首先來看看JUnit4.0以前,我們怎樣編寫測試用例:

- 測試用例必須繼承自"junit.framework.TestCase";
- 測試用例函數(shù)必須以"test"開頭;
- 用assert的系列函數(shù)來驗證結果。
如果用JUnit4.0重寫,將是這個樣子:

- 不用再繼承自"junit.framework.TestCase",TestNG批評JUnit的一個方面就是在JUnit中,每一個測試用例都會實例化一份TestCase,帶來效率的降低。JUnit4.0確實修改了這樣的設計。
- 測試函數(shù)名稱不用再以"test"開頭,而用Annotation"@Test"來修飾;
- assert系列函數(shù)沒有大的改變;
- 如果希望用老的JUnit Runner來運行JUnit4.0的測試用例,需要用Junit4TestAdapter來Adapt一下。
- 或者可以用新的JUnit4的Runner來運行。
- java org.junit.runner.JUnitCore LibraryTest
其中,用"@Test" Annotation來修飾測試用例是JUnit4.0的一個大Feature,這也正是這種Metadata應該發(fā)揮作用的地方。
"@Test"有兩個非常有用的參數(shù):
1) 預期會拋出的異常檢測
"@Test"的"expected"參數(shù)用來說明希望拋出的異常,如果運行時沒有拋出這個異常,測試用例就被標識為失敗。
2) 預期運行時間

"@Test"有一個timeout的參數(shù)用來說明這個測試用例運行的時間最長應該為多少,如果時間超出,則標識為失敗。
- @Test (timeout=10)
TestNG批評JUnit的另一個方面是所有的測試用例函數(shù)都會在測試執(zhí)行前執(zhí)行setUp,在測試后執(zhí)行tearDown,不僅效率很低,也會帶來很多問題(比如一次性的數(shù)據(jù)庫鏈接等等)。
JUnit4.0這樣解決這個問題:
引入Annotation"Before", "After", "BeforeClass", "AfterClass"。
"Before"修飾的函數(shù)將會在每個測試運行前運行,"After"修飾的函數(shù)將在每個測試用例運行后運行。JUnit4.0支持任意數(shù)量的"Before"和"After" Annotation,并且支持繼承。"Before"修飾函數(shù)的執(zhí)行順序為父類的在前,繼承類在后,"After"則相反,繼承類在前,父類在后。

"BeforeClass"修飾的函數(shù)將會在所有的測試用例運行前運行一次(只運行一次), "AfterClass"則會在所有的測試用例運行后運行一次(只運行一次)。

JUnit4.0還有一個有用的Annotation "@Ignore",它用來修飾將被忽略的函數(shù),用"@Ignore"修飾的測試用例函數(shù)將不會執(zhí)行。這個Annotation支持一個字符串參數(shù),用來說明忽略的原因,比如:
- @Ignore(“Database is down”)
TestNG則采用配置文件的辦法解決這個問題,兩種方法各有利弊。
Reference:
JUnit 4.0 in 10 Minutes: A Quick Reference Guide [PDF] - Gunjan Doshi
注:所有代碼和插圖都來自于原文。
Popularity: 24%
Related entries: