單元測(cè)試實(shí)踐小結(jié)[3]

字號(hào):

例子只測(cè)試執(zhí)行流程,實(shí)際實(shí)踐中還可以驗(yàn)證所有的參數(shù)。
     我們還可以考慮利用AOP來(lái)改進(jìn)這個(gè)測(cè)試方法。then, we needn't to do the same work,each time. We repeat it only once.
     討論完測(cè)試的關(guān)注點(diǎn)后,需要看看實(shí)際面臨的具體困難
     職責(zé)不明確
     類或類方法的職責(zé)不明確,違反SRP原則.一個(gè)類或方法處理了本不該有它處理的邏輯,使得單元測(cè)試需要關(guān)心過(guò)多的外部關(guān)聯(lián)類
    靜態(tài)方法
     靜態(tài)方法使得調(diào)用者直接面對(duì)實(shí)際的服務(wù)類,難以通過(guò)其他方式替換其實(shí)現(xiàn),也難以擴(kuò)展
     直接訪問(wèn)對(duì)象實(shí)例
     調(diào)用者直接實(shí)例化服務(wù)對(duì)象,從而使用服務(wù)對(duì)象提供的服務(wù).同靜態(tài)方法一樣,直接面對(duì)其服務(wù)類
     J2se和J2ee標(biāo)準(zhǔn)庫(kù)或者其他類庫(kù)
     標(biāo)準(zhǔn)類庫(kù)中有非常多的接口調(diào)用使得調(diào)用者難以測(cè)試 e.g JNDI, JavaMail, JAXP
    準(zhǔn)備數(shù)據(jù)及其困難
     編寫測(cè)試用例需要外部準(zhǔn)備大量的數(shù)據(jù)
     針對(duì)這些困難,可用解決方法如下:
     重構(gòu)系統(tǒng)。
     對(duì)于職責(zé)不明確的代碼,只有通過(guò)重構(gòu)才可以達(dá)到單元測(cè)試的目的。
     Self-Delegate test pattern
     針對(duì)于class的測(cè)試,使用自代理測(cè)試模式, 使得測(cè)試時(shí),可以重寫被測(cè)試類的一些方法.達(dá)到測(cè)試的目的.通過(guò)extend class override methods來(lái)實(shí)現(xiàn)。Inner class mock方法也一樣。不過(guò)這種方法比較別扭。