Andrew Glover在最近的developerWorks上發(fā)表了一篇文章《追求代碼質(zhì)量: 不要被覆蓋報(bào)告所迷惑》,我覺得又是一篇防止被忽悠的好文章。當(dāng)然,作為單元測(cè)試的狂熱分子,作者在文章中反復(fù)強(qiáng)調(diào)的不是不要單元測(cè)試和達(dá)到較高的測(cè)試覆蓋率,而是苦口婆心地勸告大家,高的測(cè)試覆蓋率并不代表測(cè)試良好的代碼。所以,作為項(xiàng)目經(jīng)理的你當(dāng)被項(xiàng)目成員拿著極高測(cè)試覆蓋率報(bào)告來(lái)交差時(shí),你得留個(gè)心眼;而當(dāng)你拿著覆蓋報(bào)告去忽悠客戶的時(shí)候,是不是也要想想客戶也有可能會(huì)讀這篇文章呢?這又讓我想起幾位熱心讀者在《我為什么討厭框架》中的留言,所以,我得聲明一下:沒(méi)采用框架的系統(tǒng),80%不是架構(gòu)良好的系統(tǒng),但反過(guò)來(lái)不一定成立,所以不要因?yàn)椴捎昧丝蚣芏哒頍o(wú)憂;沒(méi)有單元測(cè)試或者極低覆蓋率的代碼,80%是難以維護(hù)的代碼,同樣反過(guò)來(lái)也不一定成立,所以,不要為了高測(cè)試覆蓋率而逼著項(xiàng)目成員編寫無(wú)用的單元測(cè)試。
稍稍記錄一下文章的主要內(nèi)容:
測(cè)試覆蓋度量
行覆蓋也叫語(yǔ)句覆蓋,用以指出代碼的哪些行被執(zhí)行了
分支覆蓋 則試圖度量決策點(diǎn)(比如包含邏輯
測(cè)試覆蓋的作用
稍稍記錄一下文章的主要內(nèi)容:
測(cè)試覆蓋度量
行覆蓋也叫語(yǔ)句覆蓋,用以指出代碼的哪些行被執(zhí)行了
分支覆蓋 則試圖度量決策點(diǎn)(比如包含邏輯
AND
或 OR
的條件塊)的覆蓋率測(cè)試覆蓋的作用
- 估計(jì)修改已有代碼所需的時(shí)間
- 評(píng)估代碼質(zhì)量
- 評(píng)定功能測(cè)試