JBuilder2005單元測試之JUnit框架
發(fā)表時(shí)間:2024-06-02 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]簡單的框架 JUnit是由Erich Gamma和Kent Beck開發(fā)的開源測試框架,JBuilder集成了這個(gè)框架并對此做了擴(kuò)展。JUnit之所以流行并為廣大的開發(fā)人員所推崇,一是因?yàn)樗鼘?shí)戰(zhàn)性強(qiáng),功能強(qiáng)大,二是因?yàn)樗鼘?shí)在簡單。一個(gè)產(chǎn)品或框架要能有生命力,最好都具備這樣的特點(diǎn)。 簡單地講...
簡單的框架
JUnit是由Erich Gamma和Kent Beck開發(fā)的開源測試框架,JBuilder集成了這個(gè)框架并對此做了擴(kuò)展。JUnit之所以流行并為廣大的開發(fā)人員所推崇,一是因?yàn)樗鼘?shí)戰(zhàn)性強(qiáng),功能強(qiáng)大,二是因?yàn)樗鼘?shí)在簡單。一個(gè)產(chǎn)品或框架要能有生命力,最好都具備這樣的特點(diǎn)。
簡單地講這個(gè)框架提供了許多斷言(assert)方法,允許你設(shè)置測試的規(guī)則,如:assertEquals()、assertNull()、assertNotSame()、assertTrue()等方法,一個(gè)測試用例包括了多個(gè)斷言,當(dāng)運(yùn)行測試用例后,JUnit運(yùn)行器會(huì)報(bào)告哪些斷言沒有通過,開發(fā)人員就可順藤摸瓜搞個(gè)水落石出了。而傳統(tǒng)的測試方法需要將期望的結(jié)果用諸如System.out.println()等語句將過程信息打印到控制臺或日志中,由開發(fā)人員觀察輸出信息以判斷是否正確,現(xiàn)在這種"觀察"的工作由JUnit的那些assertXxx()方法自動(dòng)完成。
JUnit的測試框架類結(jié)構(gòu)很簡單,主要由3個(gè)類組成,其類圖關(guān)系如下圖所示:
圖 錯(cuò)誤!文檔中沒有指定樣式的文字。JUnit測試框架類結(jié)構(gòu) ·junit.framework.Test:測試接口。
·junit.framework.TestCase:測試用例類,業(yè)務(wù)類的測試用例類只需要承繼這個(gè)TestCase,根據(jù)情況編寫若干個(gè)public void testXxx()方法,在方法中通過assertYyy()定制若干測試規(guī)則就可以了。
·junit.framework.TestSuite:測試套件類,它可以將多個(gè)測試用例類捆綁在一起運(yùn)行,也可以捆綁另一個(gè)測試套件。
測試固件(Fixture)
一個(gè)測試用例可以包含若干個(gè)testXxx()測試方法,測試用例測試一個(gè)或多個(gè)類API接口的正確性,當(dāng)然在調(diào)用類API時(shí),需要事先創(chuàng)建這個(gè)類的對象及一些關(guān)聯(lián)的對象,這組對象就稱為測試固件(Fixture),相當(dāng)于測試用例的"工作對象"。
我們在前面說過,一個(gè)測試用例類可以包含多個(gè)testXxx()方法,在運(yùn)行時(shí),每個(gè)測試方法都對應(yīng)一個(gè)測試用例類的實(shí)例。當(dāng)然,你可以在具體的testXxx()方法里聲明并實(shí)例化業(yè)務(wù)類的實(shí)例,在測試完成后再銷毀它們。但是,這么一來你就要在每個(gè)testXxx()方法中都重復(fù)這些代碼,因?yàn)門estCase實(shí)例被運(yùn)行時(shí),依照以下步驟運(yùn)行:
1.創(chuàng)建測試用例的實(shí)例。
2.調(diào)用setUp()方法,執(zhí)行一些初始化工作。
3.運(yùn)行testXxx()測試方法。
4.調(diào)用tearDown()方法,執(zhí)行銷毀對象的工作。
如果測試用例類中有多個(gè)testXxx()方法,且它們都需要使用到相同的一組對象,我們可以在setUp()中實(shí)例化這組對象,并在tearDown()中銷毀它們。要編寫測試固件,依照以下步驟進(jìn)行:
1.創(chuàng)建TestCase類的子類。
2.在子類中聲明若干個(gè)測試所用的對象。
3.覆蓋setUp()方法,在方法中實(shí)例化這些對象。
4.覆蓋tearDown()方法,釋放這些對象的資源。
如下面即是一個(gè)簡單的測試固件:
代碼清單 錯(cuò)誤!文檔中沒有指定樣式的文字。測試固件
1. public class MoneyTest extends TestCase
2. {
3. private Money f12CHF;//12瑞士法郎
4. private Money f14CHF; //14瑞士法郎
5. private Money f28USD; //28美國美元
6. protected void setUp() {
7. f12CHF= new Money(12, "CHF");
8. f14CHF= new Money(14, "CHF");
9. f28USD= new Money(28, "USD");
10. }
11. protected void tearDown(){}
12. }
第3~5行聲明了3個(gè)Money類對象(測試固件),在setUp()方法中實(shí)例化這3個(gè)對象(第7~9行),由于這些對象可以被垃圾進(jìn)行直接回收,所以在tearDown()中不做任何操作。
測試用例(TestCase)
有了測試固件,就可以開始編寫測試用例的測試方法了。當(dāng)然你也可不需要測試固件而直接編寫測試用例方法。下面我們在測試固件的基礎(chǔ)上添加測試用例方法testMoneyBag(),代碼如下所示:
代碼清單 錯(cuò)誤!文檔中沒有指定樣式的文字。測試用例方法
1. public class MoneyTest extends TestCase
2. {
3. private Money f12CHF;//12瑞士法郎
4. private Money f14CHF; //14瑞士法郎
5. private Money f28USD; //28美國美元
6. protected void setUp() {
7. f12CHF= new Money(12, "CHF");
8. f14CHF= new Money(14, "CHF");
9. f28USD= new Money(28, "USD");
10. }
11. public void testMoneyBag()
12. {
13. Money bag[]= { f26CHF, f28USD };
14. MoneyBag expected= new MoneyBag(bag);
15. assertEquals(expected, f12CHF.add(f28USD.add(f14CHF)));
16. }
17. protected void tearDown(){}
18. }
測試方法都必須以test為前綴,且必須是public void的,運(yùn)行器以此為反射查找規(guī)則找到這些測試用例方法。在一個(gè)方法中可以包括多個(gè)assertYyy()方法,每個(gè)assertYyy()方法都是一個(gè)測試規(guī)則。像第15行的assertYyy()斷言方法即為測試Money的add()方法和MoneyBag類正確性的測試規(guī)則。
你可以在MoneyTest中添加多個(gè)public void testXxx()方法,運(yùn)行器為每個(gè)方法生成一個(gè)測試用例實(shí)例,分別運(yùn)行。
測試套件(TestSuite)
如果每次只能運(yùn)行一個(gè)測試用例,那么又陷入了我們前面所談到的傳統(tǒng)測試的窘境:手工去運(yùn)行一個(gè)個(gè)測試用例,測試套件專門為解決這一問題而來。它通過TestSuite對象將多個(gè)測試用例組裝成到一個(gè)測試套件,則測試套件批量運(yùn)行。需要特殊指出的是,可以把一個(gè)測試套件整個(gè)添加到另一個(gè)測試套件中,就象小筐裝進(jìn)大筐里變成一個(gè)篋一樣。
測試套件類也通過承繼TestCase類實(shí)現(xiàn),只不過它提供了一個(gè)public static Test suite()靜態(tài)方法,在該方法中將多個(gè)測試用例捆綁組裝在一起。一個(gè)典型的測試套件代碼如下所示:
代碼清單 錯(cuò)誤!文檔中沒有指定樣式的文字。測試套件
1. public class MoneyTestSuite extends TestCase
2. {
3. public TestSuite1(String s)
4. {
5. super(s);
6. }
7. public static Test suite()
8. {
9. TestSuite suite = new TestSuite();
10. suite.addTestSuite(MoneyTest.class);
11. suite.addTestSuite(MoneyBag.class);
12. return suite;
13. }
14. }
在第9行中聲明并實(shí)例化了一個(gè)TestSuite,在第10、11行分別加入一個(gè)測試用例。你可以通過suite.addTest(Test t)方法添加一個(gè)套件。這樣運(yùn)行這個(gè)套件就可以自動(dòng)運(yùn)行所有測試用例的測試方法了。
測試運(yùn)行器
JUnit提供了3個(gè)標(biāo)準(zhǔn)的測試運(yùn)行器運(yùn)行這些測試用例或測試套件,這3個(gè)測試運(yùn)行器分別是:
·junit.textui.TestRunner:文本測試運(yùn)行器。
·junit.awtui.TestRunner:使用AWT組件界面的測試運(yùn)行器。
·junit.swingui.TestRunner:使用Swing組件界面的測試運(yùn)行器。
下面是基于AWT組件的測試運(yùn)行器,如下圖所示:
圖 錯(cuò)誤!文檔中沒有指定樣式的文字。AWT測試運(yùn)行器
·Test class name:指定測試用例類和測試套件類。
·一個(gè)進(jìn)度條:表示運(yùn)行測試的執(zhí)行進(jìn)度,進(jìn)度條下是正確、錯(cuò)誤、失敗的測試統(tǒng)計(jì)數(shù)。
·Error and Failures:列出了測試錯(cuò)誤和失敗的列表,點(diǎn)選其中的一個(gè)選項(xiàng)時(shí),JUnit在窗口底部列出錯(cuò)誤跟蹤跡。
提示:
JBuilder提供了方便的運(yùn)行測試用例和測試套件類的方法,你只須點(diǎn)擊鼠標(biāo)右鍵就可直接調(diào)用了。此外,JBuilder提供了一個(gè)JBTestRunner測試運(yùn)行器,在功能和易用性上非JUnit提供的測試運(yùn)行器所能媲美。JBuilder支持JUnit所提供的兩個(gè)測試運(yùn)行器:junit.textui.TestRunner和junit.swingui.TestRunner。
<>