單元測試,測試什麼?
我們一直強調單元測試的重要性,但是有一個問題可能沒有認真去想過,測試是重要的,但是我們測試什麼呢?最近重讀《單元測試之道》,書中給出了答案:Right-BICEP
1.Right——正確
很顯然,如果代碼運行的結果與你預期的不符合,那麼這段代碼肯定是有問題的。需要注意的是,Right並意味著正確,因為正確隻是相對你所期望的結果而言,而對於用戶需求也許就是錯誤的。
2.B——邊界條件
尋找邊界條件是單元測試最有價值的工作之一,因為bug一般出現在邊界條件上,你常常需要考慮下麵這些邊界條件:
1)完全偽造或者不一直的數據進行輸入
2)格式錯誤的數據,比如錯誤的URL,Email地址
3)空值或者不完整值,比如0,null
4)與常理相去甚遠的數據,比如人有10000歲?
5)如果要求傳入的是一個不允許重複數據的list,你傳入一個有重複數據的看看出現什麼情況
6)如果需要傳入的有序的集合,你傳入一個無序的看看結果
7)不按照次序地執行,比如未登錄就嚐試操作某功能等
對於邊界條件,可以按照CORRECT的順序去嚐試:
Conformance——一致性,值是否和預期的一樣
Ordering——順序性,值是否如預期的那樣,有序或者無序
Range——區間性,值是否處於合理的範圍內
Reference——引用,值是否引用了代碼無法空值的外部資源
Existence——值是否存在,為空?為0?不在集合內?
Cardinatity——基數性,檢查你的函數能否正確地計數,不多不少
Time——所有的事件的發生是否按照預期的順序,性能上滿足要求?
3.Inverse——檢查反向引用
如果方法導致某個結果,嚐試以另一個方法能否返回最初的狀態?與原狀態是否符合預期?
4。Cross——交叉檢查
通過不同的方法檢查一個方法產生的結果是否正確,比如用Math.sqrt方法檢查自己編寫的求平方根的方法是否正確。另外的方式,以一種數量去檢查另一種數量,比如圖書館借出的書加上架上的書的總數是固定,可以用借出的書來檢查架上的書的數量是否正確。
5.E——強製錯誤條件的產生
一般我們所能想到的環境因素:
1)內存耗光
2)磁盤用滿
3)時鍾出問題
4)網絡不可用或者有問題
5)係統過載
6)調色板顏色數目有限
7)顯示分辨率過高
再比如JDK版本差異,我就為這個問題頭痛過:)
6.Performance——性能
每天或者每隔幾天運行一下一個粗糙簡單的性能測試,能夠保證你不會在給用戶演示的時候出現尷尬的場麵。
盡管書上是講了這麼多測試這個、測試那個,我想真實的項目場景中應該根據需要采取特定的測試策略,比如你總不能對於一個單機應用需要考慮地震震斷海底光纜引發的問題。就我自己而言,因為項目組中似乎隻有我對JUnit等單元測試工具充滿興趣,有經驗的老程序員是自己寫一個帶Main方法的Test類進行測試,而更多的人根本就不知道單元測試或者知道也不感興趣,在沒有壓力的情況下,要求自己考慮這麼多的測試內容,難矣。今天試用了下NUnit,感覺比JUnit難用多了,JUnit與Eclipse的結合非常簡便。
文章轉自莊周夢蝶 ,原文發布時間5.17
最後更新:2017-05-17 12:32:23