這篇文章描述了:
• 單元測(cè)試的信任
• 測(cè)試正確事件
• 創(chuàng)建維護(hù)測(cè)試
• 創(chuàng)建易讀測(cè)試
這些天有很多的關(guān)于單元測(cè)試的和在不同的場(chǎng)景下為他們的應(yīng)用程序編寫單元測(cè)試(起始于, 我們2005年六月的 MSDN®Magazine 中有關(guān)測(cè)試你的數(shù)據(jù)層的文章, Know Thy Code: Simplify Data Layer Unit Testing using Enterprise Services)的討論。這些意味著有很多的開(kāi)發(fā)者自言自語(yǔ)(或者對(duì)于他們的團(tuán)隊(duì))到:“哎,我們也需要開(kāi)始編寫測(cè)試了!”因此他們開(kāi)始編寫單元測(cè)試上面的單元測(cè)試直到他們達(dá)到了一個(gè)測(cè)試自己已經(jīng)成為問(wèn)題的程度;蛟S維護(hù)他們是一個(gè)太過(guò)困難,花費(fèi)太長(zhǎng)時(shí)間,或者他們并沒(méi)有足夠的易讀性以便于理解,更或者他們本身存在bugs有一點(diǎn)是能夠使得我們的開(kāi)發(fā)人員可以下定決心去做的,那就是: 花費(fèi)他們寶貴的時(shí)間以用來(lái)改進(jìn)提高他們的測(cè)試或者忽略其中的問(wèn)題, 從而有效的甩掉那些艱苦的工作。而這些困難的原因僅僅是因?yàn)槟切┎皇炀毜膶懭雴卧獪y(cè)試。.在這篇文章中,我將為大家?guī)?lái)在過(guò)去一年多時(shí)間里我在開(kāi)發(fā),提供咨詢和培訓(xùn)開(kāi)發(fā)者等方面有總結(jié)出來(lái)的一些最重要的練習(xí)和試驗(yàn)。這些小的技巧可以幫助您寫出更有效的,可維護(hù),和魯棒性更好的單元測(cè)試。同時(shí)我希望這些總結(jié)和忠告可以幫助您避免一些由于錯(cuò)誤引起的大量的時(shí)間的消耗。
單元測(cè)試的信任
在這個(gè)部分,我將略述出一些最通用的信任,這些信任來(lái)自于在使用大量單元測(cè)試獲得的好處和解釋為什么這些信任通常不是必須真實(shí)的。然后我們會(huì)幫助您在您的工程中擁有這些信任。
更加簡(jiǎn)單的跟蹤Bug 當(dāng)然這并不是必須的,那么您怎么知道您的測(cè)試是正確的? 是否存在在一些測(cè)試環(huán)節(jié)測(cè)試失敗的情況?另外您又如何知道您的測(cè)試覆蓋了系統(tǒng)中多少的代碼量?是否測(cè)試到了程序中的錯(cuò)誤,錯(cuò)誤又在哪里等等的問(wèn)題。
當(dāng)你在你的單元測(cè)試中發(fā)現(xiàn)了bug后又會(huì)發(fā)生什么事情哪?你會(huì)突然間得到很多與愿意錯(cuò)誤的反饋,bug被發(fā)現(xiàn),但是問(wèn)題并不在你測(cè)試的代碼中。你的測(cè)試的邏輯存在一個(gè)bug,因此測(cè)試失敗了。這些bug也是您最難被檢查出來(lái)的,因?yàn)槟ǔ?huì)去檢查您的應(yīng)用程序而不會(huì)去檢測(cè)你的測(cè)試環(huán)節(jié)。在這部分中,我會(huì)展示給你如何確認(rèn)大量的單元測(cè)試,事實(shí)上就是使得跟蹤bug變得更加容易。
代碼更加便于維護(hù) 從最終點(diǎn)考慮,你可以傾向于認(rèn)為這些信任并不是必須的,當(dāng)然你是對(duì)的,讓我們?nèi)フf(shuō),代碼中每個(gè)邏輯方法至少要有一個(gè)測(cè)試方法(當(dāng)然,你可能擁有一個(gè)以上的方法)在一個(gè)好的測(cè)試覆蓋的工程中,大概有百分之六十的代碼是能夠得到單元測(cè)試的,現(xiàn)在不得不考慮到測(cè)試也是要被維護(hù)的,如果針對(duì)一個(gè)復(fù)雜的邏輯方法你有20個(gè)測(cè)試,那么當(dāng)你向這個(gè)方法添加一個(gè)參數(shù)時(shí)會(huì)發(fā)生什么事情哪?測(cè)試無(wú)法編譯。當(dāng)你修改了類的結(jié)構(gòu)的時(shí)候同樣會(huì)發(fā)生這樣的事情。這時(shí)你突然發(fā)現(xiàn)為了能讓你的應(yīng)用程序繼續(xù)工作你自己需要改變大量的測(cè)試。當(dāng)然這會(huì)花費(fèi)你大量的時(shí)間。
為了使這個(gè)信任確認(rèn)下來(lái),你需要確認(rèn)你的測(cè)試是便于維護(hù)的。保持DRY規(guī)則寫入:不要重復(fù)你自己。我們將更加接近的來(lái)看這個(gè)問(wèn)題。
更多軟考資料請(qǐng)?jiān)L問(wèn):考試吧軟件水平考試欄目
希望與更多網(wǎng)友交流,請(qǐng)進(jìn)入考試吧軟件水平考試論壇
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |