測試是浪費時間,我的程序肯定沒問題

盡管關于測試驅動開發(TDD)的書和文章有成百上千之多,仍然有很多人從未感受過測試的強大力量。

之所以不愿意去寫測試程序不外乎有以下幾個理由:

1:太費時間。
2:不值得。
3:我很懶。
4:我不知道如何做。
5:我知道我的程序好用,我運行過一次,沒出問題。
6:我是超人,我從來不犯錯誤。
除非你的答案是6.(如果是這樣,我很羨慕你),否則,你應該繼續讀下去。

Alt text
Alt text

讓我們從一個簡單的例子開始。就說你要寫一個Email地址校驗程序。

你也許會使用正則表達式,或手工實現每個字符的對比,來完成這個任務。

現在你想驗證一下你的代碼是否有效。你會怎么做?你可以手工輸入不同的值來驗證它是否符合你的要求,結果你就測試了像下面的這些東西:

Alt text
Alt text

如果你要改變/調整校驗算法會發生什么?你需要把之前所有的過程全部重復一遍,把每個值都再輸入一遍,看看校驗的結果。如果讓計算機自動的幫你校驗這些是不是會更好些呢?

通過把測試過程自動化,你可以在任何時候對程序進行任何遍次的測試。這不僅僅在以后會節省你大量的時間,而且會增加你的自信心,因為每次當你感覺到程序可能出錯時,只要運行一下你的測試程序,看看測試結果就行了。

現在設想一下你正在編寫一個更加復雜的程序,比如XML解析器。

你不可能編寫出解析器后不去測試它,問題是,你如何測試它?通常,你會創建一個XML樣板文件,把它輸入解析器里,手工檢查解析的結果。當你看到解析器按照要求輸出了你期望的結果后,你確信你完成了任務,解析器沒問題。

問題就在于如果你發現了一個Bug。那你就需要去修改你的代碼,再驗證一次它是否好用。可是我們程序員都是一群懶人,我們會只測試我們遇到的這個Bug,幾乎從來不會去測試解析器的其它部分。這會產生什么問題呢?你能確保沒有把什么東西改壞?

當你寫了單元測試程序后,這個工作流程會變的怎樣?

首先,你已經對程序進行過測試,之前你必須對每個函數進行手工的測試,手工的檢查輸出結果。如果這種事情你只需要做一次,那也沒什么了,但當有東西出錯時,你不想一遍一遍的重復做這個事情,沒有人喜歡來回重復的做相同的事情,特別是無聊的事情。

另一種情況,你為你的解析器里的每個功能都寫了自動測試程序。在這個例子中,你已經測試過你的程序,對這個過程你并不陌生。你需要做的是把手工的檢查改為assertions,它們會為你自動測試程序。

當Bug出現時,巨大的變化發生了。

如果沒有自動化測試,你必須手工的檢查所有的東西來確保你在修正一個Bug時不會引入其它的錯誤。當有數個Bug出現時,你會變得極不耐煩,你開始不再檢查其它部分的代碼,只關注你的這個Bug。但假如你為程序寫好了自動化測試,你唯一要做的就是點擊一次按鈕,讓所有的測試程序運行起來,你馬上就能看到測試結果,幾乎不需要在其它任何事情。

當有了測試程序后,修改Bug是怎樣進行的?

首先,你需要重現這個Bug。無論如何,在你修改前,你必須要認定這個Bug是否真實的存在。如何做到這些?你要寫出一個測試用例來重現這個bug,這個必須要在你做任何的修改這個bug的工作之前完成。

如果這個bug不能重現,問題就可能出自其它地方,如果不能用自動化測試來重現這個bug,你可能在錯誤的地方修改了這個bug,很可能改壞了你的程序。當你寫出測試程序,你必須先運行它確保它會失敗。如果測試沒有失敗,什么地方可能出了問題,你沒能正確的重現它。

當你修改了這個Bug,你也有了針對它的測試程序,你可以立即發現這個bug是否還會出現。

當你這時又發現另外一個bug時該怎么做?

相同的做法。寫一個測試程序,重現這個bug。即使你沒有時間來立即修正這個bug或者這不是個致命的bug,你也應該有個能夠讓它重現的測試程序,當日后你回來解決這個問題時,你就能知道該做什么了。

本文轉自:碼農網
文章鏈接: http://www.codeceo.com/article/test-is-waste-time.html

Alt text
Alt text
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,247評論 6 543
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,520評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,362評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,805評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,541評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,896評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,887評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,062評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,608評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,356評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,555評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,077評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,769評論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,175評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,489評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,289評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,516評論 2 379

推薦閱讀更多精彩內容

  • 盡管關于測試驅動開發(TDD)的書和文章有成百上千之多,仍然有很多人從未感受過測試的強大力量。 之所以不愿意去寫測...
    alston123閱讀 294評論 0 2
  • 文章來自:http://blog.csdn.net/mj813/article/details/52451355 ...
    好大一只鵬閱讀 9,213評論 2 126
  • 1.測試與軟件模型 軟件開發生命周期模型指的是軟件開發全過程、活動和任務的結構性框架。軟件項目的開發包括:需求、設...
    Mr希靈閱讀 21,980評論 7 278
  • 1.測試與軟件模型 軟件開發生命周期模型指的是軟件開發全過程、活動和任務的結構性框架。軟件項目的開發包括:需求、設...
    宇文臭臭閱讀 6,745評論 5 100
  • “煩死了,再哭小心我揍你…” 小侄女平時都很乖,摔一下自己爬起來又開始玩了。哭的正傷心,只要只要我拿一個糖給她,或...
    我不是林小小閱讀 372評論 0 2