Cucumber 入门一
(轉自:http://www.cnblogs.com/jarodzz/archive/2012/07/02/2573014.html)
第一次看到Cucumber和BDD(Behavior Driven Development, 行為驅動開發(fā)),是在四年前。那時才開始工作,對軟件測試工具相當著迷。僅僅要是開源的、免費的,我就一定要下載,安裝,試用。有的工具用途單一、好懂(如Jmeter,Watir);有的工具,則涉及到一些軟件領域的獨有概念,不好懂,(如STAF,Cucumber)。好懂的,我上手、試用、推廣,不亦樂乎;不好懂的,就僅僅能丟在一邊,這里面就包含Cucumber。
再次看到Cucumber,已是兩年前。我對軟件開發(fā)的理解也深了些,這一看,可真是個好東西。之后我與Cucumber間發(fā)生的故事,稍后慢慢向大家交代。這開篇的第一章,我想獻給如當年的我一樣,偶然見到了Cucumber和BDD,卻不明所以將之丟在一邊的家伙們。
初聞Cucumber的人,第一件事一定是來到Cucumber的首頁,第一眼看到的一定是
非常不幸的是,這六張圖不太好懂。由于它們依照BDD的流程來編寫的。為了讓它們好懂些,我們拋開BDD,採用傳統(tǒng)的軟件開發(fā)模型(設計->編碼->測試)來看它。傳統(tǒng)流程例如以下:
圖1,這是一個被測系統(tǒng)——用ruby編寫的計算器。
為了便于大家理解,我試著改動了一些。
?
|
|
計算器Calculator提供兩個功能: 記數(shù)push;加和sum。push將數(shù)字一一記錄在@args數(shù)組中;sum則將全部@args數(shù)組中的數(shù)字累加得和,存入@result中。寫完了被測系統(tǒng),我們來編寫測試用例。
圖2,這是為了測試上述計算器,使用Cucumber描寫敘述的測試用例。
原圖中的英文描寫敘述,被我翻譯成了中文。:
?
|
|
支持中、英等自然語言,是Cucumber的特點之中的一個。在Cucumber的幫助文檔里,聲明它支持包含中文簡體、繁體中文、日文、韓文和英文在內(nèi)的45種語言。
注意:我并未將全部英文都翻譯成中文,而是留下了幾個keyword:
Feature(功能)
Scenario(情景)
Given(給定)
And(和)
When(當)
Then(則)
它們的含義與原有自己主動化測試工具中的概念同樣,類比方下:
| Cucumber | Unit Test |
|---|---|
| Feature (功能) | test suite (測試用例集) |
| Scenario(情景) | test case (測試用例) |
| Given(給定) | setup(創(chuàng)建測試所需環(huán)境) |
| When(當) | test(觸發(fā)被測事件) |
| Then(則) | assert(斷言,驗證結果) |
Cucumber放棄了原有的keyword,而選擇了左邊五種,僅僅是為了更加流暢地支持自然語言。使用Cucumber的keyword,創(chuàng)建了測試用例,接下來,要怎樣使用Cucumber來執(zhí)行它呢?
圖3,這是執(zhí)行Cucumber時的畫面。
在一臺安裝好Cucumber的機器上,執(zhí)行上述測試用例,便能夠看到下列輸出:
?
|
|
Cucumber首先輸出的是測試用例的描寫敘述,然后3行總結性地輸出:本功能(Feature)有1個情景(1 scenario);5個步驟(5 steps),所有5個步驟均沒有定義(undefined);執(zhí)行耗時0.005秒。這里出現(xiàn)了兩個新名詞:步驟(steps)和步驟定義(step definitions)。在Cucumber中,以keywordGiven, And, When, Then開頭的每一行,為一個步驟。在兩數(shù)相加的情景中,一共同擁有5行。因此,結果顯示:5個步驟。
怎樣定義一個步驟,在Cucumber的執(zhí)行結果中也給出了具體的辦法。在3行總結性輸出后,緊接著便是:You can implement…即:你能夠使用以下的代碼段實現(xiàn)步驟定義,然后是4個小的代碼段。這些代碼段,便是Cucumber按照情境中我們使用的5個步驟,幫助我們生成的步驟定義框架。每一個框架都將內(nèi)容部分空白出來,等待填充。以下,我們來進行步驟定義。
圖4, 這是一個步驟定義的代碼示范。
我們按照圖2的樣子,向中文步驟中填入代碼,例如以下:
?
|
|
步驟定義的過程,就是向代碼段——步驟定義框架——中填入代碼的過程,即:用代碼來描寫敘述你期望的,該步驟應該運行的動作。完整的步驟定義是一個函數(shù),它:
以正則表達式作為函數(shù)名
匹配值作為參數(shù)
以測試人員輸入的代碼作為內(nèi)容
由于有了正則表達式的匹配,5個步驟僅須要4個步驟定義。“我向計算器輸入50、70”兩個步驟,都能夠用“我向計算器輸入(d+)”一個正則表達式來描寫敘述。匹配值被自己主動提取出來作為參數(shù),傳入代碼。注意:全部匹配值,即參數(shù),都是以字符串的形式傳遞,因此,我增加了num.to_i
與 result.to_i,將得到的字符串轉為整形。步驟定義完畢,再次運行Cucumber。屏幕將會顯示一片綠色。
圖5,它是一個運行Cucumber測試用例,并成功通過的畫面。
步驟定義完畢后,再次執(zhí)行Cucumber。Cucumber會找到步驟定義,并依照其代碼去執(zhí)行。結果例如以下:
?
|
|
步驟定義被我保存在目錄step_definitions下的a.rb其中。步驟定義所在文件與起始行數(shù),被打印在每一個步驟結尾,以方便查找和改動。最后,Cucumber總結性地輸出執(zhí)行結果:1個情景,5個步驟,所有通過。
圖6, 這是一個運行Cucumber測試用例,但失敗的畫面。
為了讓這個已經(jīng)十分簡單的計算器產(chǎn)生bug,我僅僅好將它改錯為:
?
|
|
再次執(zhí)行Cucumber,結果為:
?
|
|
失敗的步驟是用紅色標示出來的。在最后一個步驟中,Cucumber期待的結果為120,但得到的是70。注意:失敗的情景列表(Failing Scenarios)里列出的是:“兩數(shù)相加”這個情景所在的文件與起始行數(shù)。這是由于一個功能文件內(nèi),可能含有多個情景,這樣的輸出能夠便于找到出錯的情景。
接下來的總結性結果為:1個情景失?。? failed),5個步驟中,4個通過,1個失敗。
作為自己主動化測試工具的Cucumber,就介紹到這里。
在繼續(xù)之前,我們先回想一下本章內(nèi)容。
回想:
Cucumber是一個自己主動化測試工具
它提供了自然語言的支持,我們能夠用自然語言描寫敘述、并運行測試用例
它提供了自然語言與代碼的銜接,通過步驟與步驟定義
它提供了自然語言對代碼的調(diào)用,當步驟定義結束后,執(zhí)行Cucumber,它會自己主動調(diào)用步驟定義內(nèi)的代碼執(zhí)行
它提供了良好的斷言(assert)機制。當運行失敗時,我們能夠看到完畢的測試用例,以及明白的失敗原因。
總結
以上是生活随笔為你收集整理的Cucumber 入门一的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 第一面五星红旗(第一面五星红旗从哪里升起
- 下一篇: 摘牙套的过程是什么样的