下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
第第頁程序員為什么不寫單元測試?[2]程序員為什么不寫單元測試?[2]
發(fā)表于:2023-04-02來源::點擊數(shù):標(biāo)簽:程序員單元
程序員為什么不寫單元測試?[2]單元測試工具一個bug被隱藏的時間越長,修復(fù)這個bug的代價就越大。在《快速軟件開發(fā)》一書中已引用了大量的研究數(shù)據(jù)指出:最后才修改一個bug的代價是在bug產(chǎn)生時修改它的代價的10倍。在這里,我們需要討論的重點是單元測
程序員為什么不寫單元測試?[2]單元測試工具
一個bug被隱藏的時間越長,修復(fù)這個bug的代價就越大。在《快速軟件開發(fā)》一書中已引用了大量的研究數(shù)據(jù)指出:最后才修改一個bug的代價是在bug產(chǎn)生時修改它的代價的10倍。
在這里,我們需要討論的重點是單元測試。單元測試是一個方法層級上的測試,單元測試也是最細(xì)粒度的測試。用于測試一個類的每一個方法都已經(jīng)滿足了方法的功能要求。
在現(xiàn)代軟件開發(fā)過程中,不管是XP還是RUP都是十分重視單元測試。已經(jīng)把單元測試作為貫穿整個開發(fā)周期的一項重要的開發(fā)活動。特別是在現(xiàn)代軟件開發(fā)過程中,有經(jīng)常集成和漸近提交的方法論。由此,總結(jié)出了非常好的單元測試?yán)碚摵蛯嵺`。
二、在編寫代碼之前先編寫單元測試,即測試先行
單元測試是代碼的一部份,所有的代碼必須有單元測試,并使測試通過(像在Spring這些優(yōu)秀的開源項目中在這方面做出了非常好的例子)。
在修改代碼之前先修改單元測試,并使它測試通過。
在編寫代碼之前先編寫單元測試,會帶來非常多的好處。
在編寫代碼之前先編寫單元測試,并不是編寫代碼之前需要一次性為所有的類都事先編寫單元測試,這需要有一個粒度的控制。最大的粒度應(yīng)該控制在一個類級別上,最合適的粒度是控制在一個方法級別上。先為某一個方法編寫測試代碼,然后再為該方法編寫實現(xiàn)代碼,直到其測試通過后再為另一個方法編寫測試代碼,如此循環(huán)。單元測試在這里已經(jīng)是一個契約規(guī)范了,它規(guī)范了方法應(yīng)該做什么、實現(xiàn)什么。測試代碼遠(yuǎn)遠(yuǎn)要比難以閱讀和不會及時更新的需求文檔更有價值得多。
測試先行,鼓勵對需求的理解。如果沒有理解需求,你是不可能寫出測試代碼的,當(dāng)然你也不可能寫出好的實現(xiàn)代碼。軟件測試
測試代碼與其它文檔相比會更有價值。當(dāng)需求發(fā)生改變,實現(xiàn)代碼也相應(yīng)改變。而往往需求文檔、設(shè)計文檔得不到及時更新。測試代碼相比那些過期的文檔更具有價值。
測試先行可以編寫出最大覆蓋率的測試代碼。如果在方法的實現(xiàn)代碼編寫完后再編寫測試代碼,這時開發(fā)人員總是編寫一個正確路徑的測試代碼。它已經(jīng)很難全面的去分析其它分支邏輯。
如果我們采用測試先行,那么就自動地完成了為所有的類都編寫測試。為所有的類都編寫測試會將為你帶來非常多的好處。
我們可以很好地使用自動化測試來測試所有的類,特別是采用日構(gòu)建的系統(tǒng)??梢宰屛覀兎判牡貫轭惢蚍椒ㄌ砑有碌墓δ?。我們可以很容易地修改測試代碼并驗證修改后的代碼是有用的代碼??梢宰屛覀兎判牡貙Υa進(jìn)行重構(gòu)和進(jìn)行設(shè)計優(yōu)化。
重構(gòu)和設(shè)計優(yōu)化通常會關(guān)聯(lián)到多個類及多個方法。如果我們?yōu)樗械念惗季帉懥藴y試,我們就可以在重構(gòu)代碼后很輕松地進(jìn)行測試我們的修改是否正確。
為所有的類編寫測試,可以讓我們很容易地修改bug。當(dāng)接到一個bug報告后,我們總是先修改測試代碼,然后修改實現(xiàn)代碼,使測試成功。這樣不會因為修改一個問題而造成新問題的產(chǎn)生。
良好的單元測試策略給我們增強了對程序的信心,減少了bug的產(chǎn)生及bug的潛伏期,
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 預(yù)咨詢服務(wù)合同協(xié)議書范本
- 個人信用貸款擔(dān)保合同
- 上海市股權(quán)轉(zhuǎn)讓合同范本(年版)
- 中保人壽團(tuán)體福利保險合同條款修訂版
- 交通事故損害賠償合同
- 個人借款合同模板(擔(dān)保借款適用)
- 個人對企業(yè)借款合同書
- 個人房產(chǎn)抵押借款合同示例
- 中央空調(diào)系統(tǒng)安裝合同
- 不銹鋼工程項目承包合同
- 初中科學(xué)項目化學(xué)習(xí)促進(jìn)學(xué)生高階思維發(fā)展-基于《自制簡易吸塵器》的項目教學(xué)
- 測繪工程產(chǎn)品價格表匯編
- 拘留所教育課件02
- 語言和語言學(xué)課件
- 《工作場所安全使用化學(xué)品規(guī)定》
- 裝飾圖案設(shè)計-裝飾圖案的形式課件
- 2022年菏澤醫(yī)學(xué)專科學(xué)校單招綜合素質(zhì)考試筆試試題及答案解析
- 護(hù)理學(xué)基礎(chǔ)教案導(dǎo)尿術(shù)catheterization
- ICU護(hù)理工作流程
- 廣東版高中信息技術(shù)教案(全套)
- 分布式光伏屋頂調(diào)查表
評論
0/150
提交評論