小時(shí)候經(jīng)常聽語文老師教我們,好的文章要“鳳頭渤滞、豬肚贬墩、豹尾”。
聽起來是個(gè)非常怪胎的形象妄呕,其實(shí)是指
文章要開頭精致簡(jiǎn)短陶舞,內(nèi)容豐富,結(jié)尾收束有力趴腋。
最近在學(xué)習(xí)寫B(tài)DD風(fēng)格的測(cè)試用例時(shí)吊说,略有一些心得。雖然在測(cè)試用例編寫的層面优炬,BDD相當(dāng)簡(jiǎn)單,看起來只是用Give,When,Then把測(cè)試分為三部分而已厅贪。但真正要用好還是有一些需要注意的點(diǎn)的蠢护。因此不吝淺薄也謅了個(gè)口訣,難以做到完全貼切养涮,但求易于記憶吧葵硕。
羊頭
從順序來看眉抬,Given部分是測(cè)試用例的頭部,但是如果按照這個(gè)順序從頭書寫用例的話懈凹,卻往往會(huì)有些迷茫蜀变。 原因很簡(jiǎn)單,Given是服務(wù)于后面測(cè)試主旨部分的介评。
所謂掛羊頭賣狗肉库北,對(duì)于單元測(cè)試來說,典型的Given部分是在設(shè)置各種mock為真正要測(cè)試的代碼設(shè)置好交互輸入们陆;而對(duì)于集成測(cè)試寒瓦,Given可以用來清理環(huán)境,初始化數(shù)據(jù)坪仇,確保用例執(zhí)行在預(yù)期的環(huán)境之中杂腰。
反模式
- 頭重腳輕
大的不成比例的Given部分,往往是目標(biāo)代碼設(shè)計(jì)失誤的一個(gè)征兆椅文。一般來說喂很,原因都在于被測(cè)試的實(shí)現(xiàn)代碼。內(nèi)聚力不足卻與外部高度耦合皆刺,職責(zé)模糊繁雜恤筛,有過多不必要的依賴…… 這時(shí)候就不要苦苦的讓測(cè)試用例委屈求全了,重構(gòu)實(shí)現(xiàn)代碼吧芹橡。
蜂腰
理想的When語句應(yīng)該只有一行代碼毒坛,即被測(cè)試的操作。它應(yīng)該成為測(cè)試用例的一條分界線林说,之前是假定煎殷,發(fā)生了某事,之后是驗(yàn)證腿箩。
這也許是Given-When-Then風(fēng)格注釋或者DSL最實(shí)際的一個(gè)目的豪直,標(biāo)出目前測(cè)試的對(duì)象。否則珠移,孤零零的一行調(diào)用很容易被淹沒在各種初始化弓乙,mock和驗(yàn)證代碼之中了。
反模式
- 大肚皮
如果發(fā)現(xiàn)不能干凈利落的用一個(gè)調(diào)用完成測(cè)試用例中的操作钧惧。很可能是實(shí)現(xiàn)代碼沒有給它的使用者提供合適的接口暇韧。特別的,如果必須把多個(gè)動(dòng)作糾結(jié)在一起完成一次有意義的操作浓瞪,這段代碼很可能有時(shí)序耦合的問題懈玻。重構(gòu)吧。 - 蜈蚣用例
如果出現(xiàn)"當(dāng)我做aaa乾颁,則xxx涂乌,然后當(dāng)我做bbb艺栈,則yyy,接下來做ccc湾盒,則……“這樣多個(gè)When Then的情況湿右,會(huì)導(dǎo)致測(cè)試的主旨不清。這樣的用例在描述How而非what罚勾。很難通過閱讀這樣的用例來理解系統(tǒng)的行為毅人。
蝎尾
一個(gè)測(cè)試用例,可以沒有Given部分荧库,甚至可以沒有When部分堰塌,卻不能沒有Then。Then部分體現(xiàn)了測(cè)試的目的所在分衫。就像蝎子尾巴一樣场刑,是真正見血的地方。在采用TDD開發(fā)的時(shí)候蚪战,可以先寫Then部分再倒推補(bǔ)充出用例的其它必要部分牵现。
另一方面,也像蝎尾伸向前方一樣邀桑,Then應(yīng)該與Given首尾呼應(yīng)瞎疼,mock了某個(gè)協(xié)作接口,就應(yīng)該有相應(yīng)的verify去檢驗(yàn)交互壁畸;設(shè)置了一些環(huán)境變量贼急,就應(yīng)該在體現(xiàn)出它們與最終執(zhí)行結(jié)果之間的關(guān)系。
反模式
- 無尾熊用例
在現(xiàn)實(shí)工程中并不是很少見捏萍,一個(gè)初始化了目標(biāo)代碼太抓,執(zhí)行了操作,卻毫無驗(yàn)證的用例令杈。測(cè)試用例唯一管用的時(shí)刻走敌,就是它失敗的時(shí)候。不會(huì)失敗的測(cè)試是無用的逗噩,或者說除了給測(cè)試覆蓋率注水以外毫無用處掉丽。