在這篇文章中伞芹,我們來仔細分析一下這個測試框架中的每一個細節(jié)掀鹅,知其然更要知其所以然,才能更加熟練地應(yīng)用JUnit4单鹿。
(一)所必須導(dǎo)入的包
在測試類中用到了JUnit4框架,自然要把相應(yīng)地Package包含進來深纲。最主要地一個Package就是org.junit.*仲锄。把它包含進來之后,絕大部分功能就有了湃鹊。還有一句話也非常地重要“import static org.junit.Assert.*;”儒喊,我們在測試的時候使用的一系列assertEquals方法就來自這個包。大家注意一下币呵,這是一個靜態(tài)包含(static)怀愧,是JDK5中新增添的一個功能侨颈。也就是說,assertEquals是Assert類中的一系列的靜態(tài)方法芯义,一般的使用方式是Assert. assertEquals()哈垢,但是使用了靜態(tài)包含后,前面的類名就可以省略了扛拨,使用起來更加的方便耘分。
代碼如下:
import static org.junit.Assert.*;
import org.junit.Before;
import org.junit.Ignore;
import org.junit.Test;
@Test
public void testAdd() {
calculator.add(2);
calculator.add(3);
assertEquals(5, calculator.getResult());//因為導(dǎo)入靜態(tài)包,直接使用方法绑警,不需要類名.方法
}
(二)測試類的聲明
大家注意到求泰,我們的測試類是一個獨立的類,沒有任何父類计盒。測試類的名字也可以任意命名渴频,沒有任何局限性。所以我們不能通過類的聲明來判斷它是不是一個測試類章郁,它與普通類的區(qū)別在于它內(nèi)部的方法的聲明枉氮,即通過對函數(shù)或者類的“標注”來區(qū)別測試類跟普通類,我們接著會講到暖庄。
(三)創(chuàng)建一個待測試的對象聊替。
你要測試哪個類,那么你首先就要創(chuàng)建一個該類的對象培廓。正如上一篇文章中的代碼:
private static Calculator calculator = new Calculator();
為了測試Calculator類惹悄,我們必須創(chuàng)建一個calculator對象。
(四)測試方法的聲明
在測試類中肩钠,并不是每一個方法都是用于測試的泣港,你必須使用“標注”來明確表明哪些是測試方法〖劢常“標注”也是JDK5的一個新特性当纱,用在此處非常恰當(dāng)。我們可以看到踩窖,在某些方法的前有@Before坡氯、@Test、@Ignore等字樣洋腮,這些就是標注箫柳,以一個“@”作為開頭。這些標注都是JUnit4自定義的啥供,熟練掌握這些標注的含義非常重要悯恍。
(五)編寫一個簡單的測試方法
首先,你要在方法的前面使用@Test標注伙狐,以表明這是一個測試方法涮毫。對于方法的聲明也有如下要求:名字可以隨便取瞬欧,沒有任何限制,但是返回值必須為void窒百,而且不能有任何參數(shù)黍判。如果違反這些規(guī)定,會在運行時拋出一個異常篙梢。至于方法內(nèi)該寫些什么,那就要看你需要測試些什么了美旧。比如:
@Test //標注為測試方法
public void testAdd() {
calculator.add(2);
calculator.add(3);
assertEquals(5, calculator.getResult());
}
我們想測試一下“加法”功能時候正確渤滞,就在測試方法中調(diào)用幾次add函數(shù),初始值為0榴嗅,先加2妄呕,再加3,我們期待的結(jié)果應(yīng)該是5嗽测。如果最終實際結(jié)果也是5绪励,則說明add方法是正確的,反之說明它是錯的唠粥。assertEquals(5, calculator.getResult());就是來判斷期待結(jié)果和實際結(jié)果是否相等疏魏,第一個參數(shù)填寫期待結(jié)果,第二個參數(shù)填寫實際結(jié)果晤愧,也就是通過計算得到的結(jié)果大莫。這樣寫好之后,JUnit會自動進行測試并把測試結(jié)果反饋給用戶官份。
(六)忽略測試某些尚未完成的方法
如果你在寫程序前做了很好的規(guī)劃只厘,那么哪些方法是什么功能都應(yīng)該實現(xiàn)定下來。因此舅巷,即使該方法尚未完成羔味,他的具體功能也是確定的,這也就意味著你可以為他編寫測試用例钠右。但是赋元,如果你已經(jīng)把該方法的測試用例寫完,但該方法尚未完成爬舰,那么測試的時候一定是“失敗”们陆。這種失敗和真正的失敗是有區(qū)別的,因此JUnit提供了一種方法來區(qū)別他們情屹,那就是在這種測試函數(shù)的前面加上@Ignore標注坪仇,這個標注的含義就是“某些方法尚未完成,暫不參與此次測試”垃你。這樣的話測試結(jié)果就會提示你有幾個測試被忽略椅文,而不是失敗喂很。一旦你完成了相應(yīng)函數(shù),只需要把@Ignore標注刪去皆刺,就可以進行正常的測試少辣。
代碼如下:
@Ignore("Multiply() Not yet implemented")
@Test
public void testMultiply() {
//測試內(nèi)容
}
(七)Fixture(暫且翻譯為“固定代碼段”)
Fixture的含義就是“在某些階段必然被調(diào)用的代碼”。比如我們上面的測試羡蛾,由于只聲明了一個Calculator對象漓帅,他的初始值是0,但是測試完加法操作后痴怨,他的值就不是0了忙干;接下來測試減法操作,就必然要考慮上次加法操作的結(jié)果浪藻。這絕對是一個很糟糕的設(shè)計捐迫!我們非常希望每一個測試都是獨立的,相互之間沒有任何耦合度爱葵。因此施戴,我們就很有必要在執(zhí)行每一個測試之前,對Calculator對象進行一個“復(fù)原”操作萌丈,以消除其他測試造成的影響赞哗。因此,“在任何一個測試執(zhí)行之前必須執(zhí)行的代碼”就是一個Fixture浓瞪,我們用@Before來標注它懈玻,如前面例子所示:
@Before
public void setUp() throws Exception {
calculator.clear();
}
這里不在需要@Test標注,因為這不是一個test乾颁,而是一個Fixture涂乌。同理,如果“在任何測試執(zhí)行之后需要進行的收尾工作”也是一個Fixture英岭,使用@After來標注湾盒。由于本例比較簡單,沒有用到此功能诅妹。
未完待續(xù)罚勾。。吭狡。