修訂測試具有非常高的可讀性和穩(wěn)定性。僅僅需要注意的是不要那么的refactor你的測試,他們可能會以一個單一的,不可讀的代碼行作為結(jié)束。應(yīng)該注意的是我在這里可能依然使用一個Verify_XX 方法,但是這并不是我真正要在這里加以說明的。
消除測試之間的依賴關(guān)系
一個測試應(yīng)該能夠自我獨(dú)立。它不應(yīng)該與其他測試相關(guān)聯(lián),也不應(yīng)該依賴任何具有特殊運(yùn)行順序的測試,它應(yīng)該能夠獲得你所寫的所有測試,可以隨意運(yùn)行所有測試或者只運(yùn)行其中的一部分,并且是以任何順序,而且要能夠確保它們無論怎樣都應(yīng)該正確的運(yùn)行。如果你不能夠執(zhí)行這個規(guī)則,你將會只在某種特殊的情況下按照預(yù)期的表現(xiàn)來運(yùn)行的狀況下結(jié)束你的測試。這樣子的話,當(dāng)你在最終期限下與此同時你還想確定你沒有向系統(tǒng)之中引進(jìn)新的問題的時候,當(dāng)然就會出現(xiàn)問題。你可能很困惑而且考慮著是不是你的代碼出現(xiàn)問題,這時,在事實(shí)上,問題其實(shí)僅僅是你的測試運(yùn)行順序所引起的。因此,你可能開始錯過了一些在測試中失敗的結(jié)果而且使它越寫越少。這將會是個長期的過程。
如果你從一個測試調(diào)出至另一個測試之中,你應(yīng)該在它們之間創(chuàng)建一個從屬關(guān)系。你本質(zhì)上說是在一個測試中測試兩個事物(我將會在下一章中解釋為什么這會成為一個問題)。就另一方面來說,如果你有測試B,它與測試A 所產(chǎn)生的狀態(tài)是不相關(guān)的,那么你會陷入“順序”陷阱之中。如果你或者其他人想要改變測試A,測試B將會暫停而且你不知它暫停的原因。對這些故障進(jìn)行故障處理會浪費(fèi)很多時間。
使用<TestInitialize()> 和<TestCleanup()>方法是本質(zhì)上能夠獲得更好的測試隔離。確定你的測試數(shù)據(jù)時刻是最新的,而且測試下對象的也具有新的實(shí)例,而且所有的狀態(tài)可以提前預(yù)知,而且無論你的測試在任何地方或者任何時間被運(yùn)行,運(yùn)行的情況都是相同的。
在一個單獨(dú)單元測試中避免多重聲明
我們將聲明故障看作一個程序弊病的象征且聲明被當(dāng)作軟件體的指示點(diǎn)或者“血液檢查”。你可以找到越多的癥狀,程序弊病就越可以輕松的被診斷和排除掉。如果你在一個測試中定義了多重聲明,只有第一個故障聲明將會以拋出異常的方式顯示出來。請參考下面插圖之中的測試代碼:
<TestMethod()> _
Public Sub Sum_AnyParamBiggerThan1000IsNotSummed()
Assert.AreEqual(3, Sum(1001, 1, 2)
Assert.AreEqual(3, Sum(1, 1001, 2) ' Assert fails
Assert.AreEqual(3, Sum(1, 2, 1001) ' This line never executes
End Sub
你可能沒有發(fā)現(xiàn)以上代碼之中其他可能的征兆。在一個故障之后,并發(fā)的聲明不會被執(zhí)行。這些不能生效的聲明可能提供了有價值的數(shù)據(jù)(或者征兆)可能能夠幫助你很快的集中的焦點(diǎn)而且發(fā)現(xiàn)潛在的問題。因此在一個獨(dú)立的測試中運(yùn)行多重聲明增加了具有很少價值復(fù)雜性。另外,聲明應(yīng)該被獨(dú)立的運(yùn)行,我們應(yīng)該設(shè)置自我獨(dú)立的單元測試以使得你具有能夠很好的發(fā)現(xiàn)錯誤的機(jī)會。
創(chuàng)建易讀性測試
如果你以前寫過單元測試,你是否在單元測試上寫了一個好的聲明行?可許不是這樣的,大多數(shù)開發(fā)者并不厭煩去寫一個好的聲明因?yàn)樗麄兏雨P(guān)心去寫測試。
假設(shè)你是團(tuán)隊(duì)中的一個新的開發(fā)者,你試圖讀一個單元測試。連接這個:
<TestMethod()> _
Public Sub TestCalcParseNegative()
Dim c As New Calc
Assert.AreEqual(1000, c.Parse("-1, -1000")
End Sub
更多軟考資料請?jiān)L問:考試吧軟件水平考試欄目
希望與更多網(wǎng)友交流,請進(jìn)入考試吧軟件水平考試論壇
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |