JBuilder 2005單元測試之慨述

azz發表於2007-08-24
JBuilder 2005單元測試之慨述[@more@]
  一個產品只有透過檢驗才能投放市場,同樣的,一個業務類也只有在經驗測試後才能保證功能的正確性,以便被其他類或程式呼叫,否則隱藏其中的Bug就蔓延開了。業務功能點測試是測試人員的職責,但業務類API的正確性必須由開發人員保證。

  回憶一下最近你所開發的系統,往往一個最難忘的情節是通宵達旦地毯式搜尋某個刁專的Bug,歷盡千辛萬苦,最終找到並解決了它。查詢一個隱藏的Bug往往是踏破鐵蹄無覓處,而找到後卻是:解決全不費功夫。

  造成這尷尬窘局有以下幾點原因:

  其一是使用增量式測試策略,即先編寫功能程式碼,在模組開發完畢後才回過頭來編寫測試用例,因為一個功能模組可能包含許多相互關聯的類,形成了層層呼叫,交錯複雜的呼叫網路,一旦發現了Bug,只得查戶口似的逐一排查,其艱辛程度可想而知。

  其二是使用不正確的測試方法,如在每個類中提供一個main()測試函式,對類中的功能方法進行測試,透過執行類的main()方法檢視類功能的正確性。在某種程式上,這或許是一個值得讚揚的工作習慣,但工作方式卻不足取。因為每個類都必須單獨執行,以執行其測試功能,並由開發人員觀察測試的正確性。隨著程式規模的擴大,類數目直線上升,原有的類也會發生程式碼的調整,一些功能點可能就變成了漏網之魚,變成了茫茫"類"海里的黑戶口,將來"違法亂紀"起來就很難監控了。

  針對這些傳統測試思想的不足,測試先行、頻繁測試、自動測試的測試思想被越來越多的開發人員所接受並付諸實踐。

  測試先行乍聽起來有點讓人不可思議,一件東西還沒有做出來就想著怎麼去測試它?仔細分析,這並不荒唐,因為這讓你在設計類時,站在呼叫者的角度去理解類的對外介面,迫使你深入理解類的外在關係,考慮介面的用途,而在具體編寫程式時才去具體考慮內部實現細節,這樣設計出介面將更易使用,結構也會更趨合理。

  頻繁測試,即指測試不應當是階段性的工作,而應當在程式編寫過程中不斷進行。因為系統中的類之間往往都存在較多的關聯關係,當更改了類的功能時,往往會有多個類受到直接或間接的影響。所以你應該頻繁測試以及早發現這種因功能、調整而引起的Bug,越早發現錯誤解決它的代價越小。頻繁測試也是XP程式設計的一個重要環節,XP程式設計總讓人覺得他們注重功能實現而忽視測試,其實他們也非常關注測試,畢竟測試可以使他們儘可能快的穩步前進。

  所謂自動測試並不是說有一個工具可以讓你像安檢器一樣,自動測試出你類中的問題。而是指應用一定的測試框架,為每個業務類編寫獨立的測試用例,類程式碼調整後,對應的測試用例同步調整。多個測試用例組成一個測試套件一起批次執行,它們就像一個強大的Bug嗅探器,一旦發現Bug就會輸出特定的資訊報告錯誤,只要一個測試用例沒有透過測試就說明程式中有問題。測試用例中所包含的測試規則完成由你定製,這個測試套件對Bug嗅探的"靈敏度"完全取決於測試用例的測試規則,框架提供編寫和執行測試用例的規範性方法。

  在編寫一個業務類時,需要相應編寫對應的測試用例,一開始挺招"慣性定律"牴觸的,因為它要求你將建立一個測試用例類,似乎需要更多的工作。但你的付出是會得到加倍回報的,隨著軟體類規模的增大你會發現,當傳統測試方法越來越捉襟見肘,窮於應付時,基於測試框架的測試技術依然"談笑自如"。當然別人這麼說,我們也不應當馬上就深信不疑,疑惑永遠是值得推崇的科學精神,我們應該透過自己的實踐卻真真切切地體會這種改進所帶來的快樂。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/10901326/viewspace-965673/,如需轉載,請註明出處,否則將追究法律責任。

相關文章