




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、測(cè)試驅(qū)動(dòng)開(kāi)發(fā)2目錄目錄測(cè)試驅(qū)動(dòng)開(kāi)發(fā)簡(jiǎn)介測(cè)試驅(qū)動(dòng)開(kāi)發(fā)入門測(cè)試與重構(gòu)3測(cè)試驅(qū)動(dòng)開(kāi)發(fā)簡(jiǎn)介測(cè)試驅(qū)動(dòng)開(kāi)發(fā)簡(jiǎn)介Why 為什么會(huì)出現(xiàn)測(cè)試驅(qū)動(dòng)開(kāi)發(fā)What 什么是測(cè)試驅(qū)動(dòng)How 測(cè)試驅(qū)動(dòng)所要達(dá)到的目標(biāo)4為什么會(huì)出現(xiàn)測(cè)試驅(qū)動(dòng)開(kāi)發(fā)這段代碼究竟想表達(dá)什么意思?奇怪了,怎么代碼跟開(kāi)發(fā)文檔上有這么大的差別???代碼現(xiàn)在越來(lái)越亂了,我都不敢修改代碼了,修改了這個(gè)地方,天曉得會(huì)引起多少別的地方出錯(cuò)啊!這個(gè)地方的代碼怎么好象在那個(gè)地方看到過(guò)???這個(gè)程序里怎么會(huì)有這么多的重復(fù)代碼呢?開(kāi)發(fā)人員開(kāi)發(fā)人員5他們到底在搞什么啊,有沒(méi)有從用戶的角度考慮啊,我新增一個(gè)票據(jù)訂單,訂單項(xiàng)竟然可以輸入負(fù)數(shù)。!。為什么會(huì)出現(xiàn)測(cè)試驅(qū)動(dòng)開(kāi)發(fā)測(cè)試人員測(cè)試
2、人員這下好了,讓他們修改了一個(gè)BUG,現(xiàn)在一下子來(lái)了這么多的BUG項(xiàng)目部在干什么啊,BUG怎么這么多,他們有沒(méi)有自己先測(cè)試一下啊6什么是測(cè)試驅(qū)動(dòng)QA 項(xiàng)目部在干什么啊,BUG怎么這么多,他們有沒(méi)有自己先測(cè)試一下啊 這下好了,讓他們修改了一個(gè)BUG,現(xiàn)在一下子來(lái)了這么多的BUG 他們到底在搞什么啊,有沒(méi)有從用戶的角度考慮啊,我新增一個(gè)票據(jù)訂單,訂單項(xiàng)竟然可以輸入負(fù)數(shù)。7測(cè)試驅(qū)動(dòng)想達(dá)到的目標(biāo)測(cè)試驅(qū)動(dòng)想達(dá)到的目標(biāo)測(cè)試驅(qū)動(dòng)是一種開(kāi)發(fā)形式 首先要編寫測(cè)試代碼 除非存在相關(guān)測(cè)試,否則不編寫任何產(chǎn)品代碼 由測(cè)試來(lái)決定需要編寫什么樣的代碼 要求維護(hù)一套詳盡的測(cè)試集clean code that work目錄目
3、錄測(cè)試失敗時(shí),才寫代碼消除重復(fù)設(shè)計(jì),優(yōu)化設(shè)計(jì)結(jié)構(gòu)代碼整潔可用9測(cè)試驅(qū)動(dòng)開(kāi)發(fā)入門測(cè)試驅(qū)動(dòng)開(kāi)發(fā)入門測(cè)試驅(qū)動(dòng)開(kāi)發(fā)簡(jiǎn)介測(cè)試驅(qū)動(dòng)開(kāi)發(fā)入門測(cè)試與重構(gòu)如何開(kāi)始如何開(kāi)始如何開(kāi)始原則測(cè)試技術(shù)原則一原則一: :測(cè)試隔離測(cè)試隔離不同代碼的測(cè)試應(yīng)該相互隔離。對(duì)一塊代碼的測(cè)試只考慮此代碼的測(cè)試,不要考慮其實(shí)現(xiàn)細(xì)節(jié)12原則二:一頂帽子原則二:一頂帽子做不同的事,承擔(dān)不同的角色。注意力集中在當(dāng)前工作上,不要過(guò)多考慮其他方面的細(xì)節(jié),保證頭上只有一頂帽子13原則三:測(cè)試列表原則三:測(cè)試列表需要測(cè)試的功能點(diǎn)很多在任何階段想添加功能需求問(wèn)題時(shí),把相關(guān)功能點(diǎn)加到測(cè)試列表中,再繼續(xù)手頭工作14原則四:先寫斷言原則四:先寫斷言編寫對(duì)功能
4、代碼的判斷用的斷言語(yǔ)句,然后編寫相應(yīng)的輔助語(yǔ)句15原則五:可測(cè)試性原則五:可測(cè)試性遵循比較好的設(shè)計(jì)原則的代碼都具備較好的測(cè)試性。比如比較高的內(nèi)聚性,盡量依賴于接口等16原則六:及時(shí)重構(gòu)原則六:及時(shí)重構(gòu)無(wú)論是功能代碼還是測(cè)試代碼,對(duì)結(jié)構(gòu)不合理,重復(fù)的代碼等情況,在測(cè)試通過(guò)后,及時(shí)進(jìn)行重構(gòu)17原則七:小步前進(jìn)原則七:小步前進(jìn)把所有的規(guī)模大、復(fù)雜性高的工作,分解成小的任務(wù)來(lái)完成每個(gè)功能的完成就走測(cè)試代碼功能代碼測(cè)試重構(gòu)的循環(huán)18范圍、粒度范圍、粒度對(duì)哪些功能進(jìn)行測(cè)試?會(huì)不會(huì)太繁瑣?什么時(shí)候可以停止測(cè)試?對(duì)那些你認(rèn)為應(yīng)該測(cè)試的代碼進(jìn)行測(cè)試大師Kent Benk 什么時(shí)候?qū)懯裁磿r(shí)候?qū)懨鞔_當(dāng)前要完成的功能
5、??梢杂涗洺梢粋€(gè) TODO 列表快速完成針對(duì)此功能的測(cè)試用例編寫測(cè)試代碼編譯不通過(guò)編寫對(duì)應(yīng)的功能代碼測(cè)試通過(guò)對(duì)代碼進(jìn)行重構(gòu),并保證測(cè)試通過(guò)如何編寫用例如何編寫用例l 操作過(guò)程盡量模擬正常使用的過(guò)程l 全面的測(cè)試用例應(yīng)該盡量做到分支覆蓋,核心代碼盡量做到路徑覆蓋l 測(cè)試數(shù)據(jù)盡量包括:真實(shí)數(shù)據(jù)、邊界數(shù)據(jù)l 測(cè)試語(yǔ)句和測(cè)試數(shù)據(jù)應(yīng)該盡量簡(jiǎn)單,容易理解l 為了避免對(duì)其他代碼過(guò)多的依賴,可以實(shí)現(xiàn)簡(jiǎn)單的樁函數(shù)或樁類(Mock Object)l 如果內(nèi)部狀態(tài)非常復(fù)雜或者應(yīng)該判斷流程而不是狀態(tài),可以通過(guò)記錄日志字符串的方式進(jìn)行驗(yàn)證如何編寫用例如何編寫用例在開(kāi)發(fā)一個(gè)新的功能之前:OK,我們知道這個(gè)method中的
6、這段代碼要做什么,而且這段代碼也足夠簡(jiǎn)單。測(cè)試隔離不同代碼的測(cè)試應(yīng)該相互隔離。對(duì)一塊代碼的測(cè)試只考慮此代碼的測(cè)試,不要考慮其實(shí)現(xiàn)細(xì)節(jié)一頂帽子做不同的事,承擔(dān)不同的角色。注意力集中在當(dāng)前對(duì)應(yīng)工作上,而不要過(guò)多的考慮其他方面的細(xì)節(jié),保證頭上只有一頂帽子測(cè)試列表需要測(cè)試的功能點(diǎn)很多在任何階段想添加功能需求問(wèn)題時(shí),把相關(guān)功能點(diǎn)加到測(cè)試列表中,然后繼續(xù)手頭工作先寫斷言編寫對(duì)功能代碼的判斷用的斷言語(yǔ)句,然后編寫相應(yīng)的輔助語(yǔ)句可測(cè)試性遵循比較好的設(shè)計(jì)原則的代碼都具備較好的測(cè)試性。比如比較高的內(nèi)聚性,盡量依賴于接口等及時(shí)重構(gòu)無(wú)論是功能代碼還是測(cè)試代碼,對(duì)結(jié)構(gòu)不合理,重復(fù)的代碼等情況,在測(cè)試通過(guò)后,及時(shí)進(jìn)行重構(gòu)
7、小步前進(jìn)把所有的規(guī)模大、復(fù)雜性高的工作,分解成小的任務(wù)來(lái)完成每個(gè)功能的完成就走測(cè)試代碼功能代碼測(cè)試重構(gòu)的循環(huán)如何編寫用例如何編寫用例對(duì)哪些功能進(jìn)行測(cè)試?會(huì)不會(huì)太繁瑣?什么時(shí)候可以停止測(cè)試?如何編寫用例如何編寫用例如果你要寫一個(gè)新的功能,請(qǐng)先寫她的測(cè)試?yán)尤绻阋跊](méi)有經(jīng)過(guò)測(cè)試的代碼上寫新的功能,請(qǐng)先寫目前代碼的測(cè)試?yán)尤绻阋狥ix一個(gè)Bug,請(qǐng)先為這個(gè)Bug寫一個(gè)測(cè)試?yán)尤绻阋貥?gòu)沒(méi)有測(cè)試過(guò)的代碼,請(qǐng)先寫一個(gè)測(cè)試?yán)尤绻惆l(fā)現(xiàn)一個(gè)邊緣例外值,請(qǐng)為她寫一個(gè)測(cè)試?yán)尤绾尉帉懹美绾尉帉懹美僮鬟^(guò)程盡量模擬正常使用的過(guò)程全面的測(cè)試用例應(yīng)該盡量做到分支覆蓋,核心代碼盡量做到路徑覆蓋測(cè)試數(shù)據(jù)盡量包括
8、:真實(shí)數(shù)據(jù)、邊界數(shù)據(jù)測(cè)試語(yǔ)句和測(cè)試數(shù)據(jù)應(yīng)該盡量簡(jiǎn)單,容易理解為了避免對(duì)其他代碼過(guò)多的依賴,可以實(shí)現(xiàn)簡(jiǎn)單的樁函數(shù)或樁類(Mock Object)如果內(nèi)部狀態(tài)非常復(fù)雜或者應(yīng)該判斷流程而不是狀態(tài),可以通過(guò)記錄日志字符串的方式進(jìn)行驗(yàn)證JUnitJUnit介紹介紹首先確定你要做什么(不是要如何做!) 比如說(shuō)一個(gè)論壇的增加用戶的功能,我們需要又一個(gè)method來(lái)增加一個(gè)用戶: public void addAccount( Account account ) 當(dāng)然包括成功增加一個(gè)用戶(在數(shù)據(jù)庫(kù)中插入一條紀(jì)錄) 還包括如果已經(jīng)由一個(gè)相同的用戶,應(yīng)該返回一個(gè)用戶已存在的消息JUnitJUnit介紹介紹然后為這
9、個(gè)功能(Method)寫單元測(cè)試?yán)? Unit Test ) 單元測(cè)試?yán)右采w這個(gè)Method的 “做什么”。 所以我們至少有了兩個(gè)測(cè)試?yán)? Test Case 1: 測(cè)試成功增加一個(gè)用戶 Test Case 2: 測(cè)試增加一個(gè)已存在的用戶 其他邊緣情況測(cè)試: Test Case 3: 傳入的Account對(duì)象為NULL目錄目錄28測(cè)試與重構(gòu)測(cè)試與重構(gòu)什么是重構(gòu)什么是重構(gòu)重構(gòu)的好處重構(gòu)的好處重構(gòu)的時(shí)機(jī)重構(gòu)的時(shí)機(jī)存在重復(fù)的時(shí)候覺(jué)察到代碼所表達(dá)的意圖不明確的時(shí)候代碼有味道的時(shí)候重構(gòu)與測(cè)試的關(guān)系重構(gòu)與測(cè)試的關(guān)系 大話西游之單元測(cè)試大話西游之單元測(cè)試 轉(zhuǎn)載轉(zhuǎn)載 “我知道這個(gè)項(xiàng)目bug很多,無(wú)法按時(shí)完成,即使老板把我炒了也是應(yīng)該的。曾經(jīng)有一個(gè)做單元測(cè)試的機(jī)
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- T-ZJCX 0045-2024 食用菌干制品
- T-ZGZS 0411-2024 T-CCPITCSC 150-2024 綠色會(huì)展廢棄物管理規(guī)范
- T-ZMDS 10024-2024 手術(shù)導(dǎo)航設(shè)備配準(zhǔn)技術(shù)要求及試驗(yàn)方法
- 2025年度高端辦公空間無(wú)償租賃合作協(xié)議
- 2025年度能源企業(yè)質(zhì)押貸款擔(dān)保合同
- 二零二五年度企業(yè)辦公用品定制化采購(gòu)合同
- 醫(yī)藥公司二零二五年度員工商業(yè)秘密保密協(xié)議及保密技術(shù)支持服務(wù)協(xié)議
- 2025年度村辦公室裝修與農(nóng)村電商市場(chǎng)拓展合作合同
- 二零二五年度酒店加盟店經(jīng)營(yíng)管理合作協(xié)議
- 2025年度物流園區(qū)開(kāi)發(fā)物業(yè)移交與倉(cāng)儲(chǔ)物流服務(wù)協(xié)議
- 2024版《初中物理總復(fù)習(xí)》課件
- 【UCM六輥軋機(jī)設(shè)計(jì)7600字(論文)】
- 滋補(bǔ)品市場(chǎng)洞察報(bào)告
- 部編版中考?xì)v史一輪復(fù)習(xí):七年級(jí)上、下冊(cè)歷史復(fù)習(xí)課件534張
- 江蘇省無(wú)錫市惠山區(qū)2024年統(tǒng)編版小升初考試語(yǔ)文試卷(含答案解析)
- 五年級(jí)下冊(cè)英語(yǔ)作文訓(xùn)練-外研版(三起)
- 7.2.1 圓柱(課件含動(dòng)畫演示)-【中職】高一數(shù)學(xué)(高教版2021基礎(chǔ)模塊下冊(cè))
- 便利店門店運(yùn)營(yíng)手冊(cè)
- 江蘇省南通市海安中學(xué)2025屆高一下生物期末綜合測(cè)試試題含解析
- 《行政倫理學(xué)教程(第四版)》課件 第1、2章 行政倫理的基本觀念、行政倫理學(xué)的思想資源
- 拆除工程施工拆除進(jìn)度安排
評(píng)論
0/150
提交評(píng)論