閱讀618 返回首頁    go 阿裏雲 go 技術社區[雲棲]


《Cucumber:行為驅動開發指南》——2.7 添加一個斷言

本節書摘來自異步社區《Cucumber:行為驅動開發指南》一書中的第2章,第2.7節,作者:【英】Matt Wynne , 【挪】Aslak Hellesy著,更多章節內容可以訪問雲棲社區“異步社區”公眾號查看

2.7 添加一個斷言

繼續遵照Cucumber的指示,我們需要為計算器程序創建一個Ruby文件。讓我們暫時先創建一個空的Ruby文件,這樣在轉入解決方案之前,我們可以繼續停留在外部並完成測試。Linux/Mac用戶可以用如下命令創建空文件:

$ touch calc.rb
如果用的是Windows,就無法使用touch命令了,可以用編輯器創建一個名為calc.rb的空文本文件,或者使用如下技巧:

C:\> echo .> calc.rb
當我們再次運行cucumber的時候,就可以看到第二個步驟通過了,並且運行到了最後一個步驟:

$ cucumber –format progress

..P

(::) pending steps (::)

features/adding.feature:6:in `Then the output should be "4"'

1 scenario (1 pending)
3 steps (1 pending, 2 passed)
0m0.021s

要讓最後一個步驟定義生效,將 features/step_definitions_calculator_ steps.rb中最後的步驟定義修改如下:

下載first_taste/07/features/step_definitions/calculator_steps.rb
Then /^the output should be "([^"]*)"$/ do |expected_output| 
 @output.should == expected_output
end

我們使用RSpec1斷言來檢查特性中指定的期望輸出與前一個步驟定義中用@output存儲的程序輸出是否匹配。如果不匹配,RSpec會產生一個錯誤,就像我們在上一個步驟定義中使用raise一樣。

現在再次運行cucumber,我們就會得到一個真正失敗的測試:

$ cucumber --format progress

..F

(::) failed steps (::)

expected: "4"
   got: "" (using ==) (RSpec::Expectations::ExpectationNotMetError)
./features/step_definitions/calculator_steps.rb:16:in `/^the output should be "([^"]*)"$/'
features/adding.feature:6:in `Then the output should be "4"'

Failing Scenarios:
cucumber features/adding.feature:3 # Scenario: Add two numbers

1 scenario (1 failed)
3 steps (1 failed, 2 passed)
0m0.021s

非常好!現在我們的測試失敗得合情合理了:它運行我們的程序,檢查輸出,然後告訴我們正確的輸出應該是怎樣的。到現在該暫停工作,休息一下了。我們已經為這個版本完成了不少艱苦的工作:一會兒等我們回來看代碼的時候,Cucumber會準確地告訴我們要使程序正確運行還需要做哪些工作。要是我們所有的需求都像這樣伴隨著一個失敗的測試交到我們麵前,構建軟件將會變得多麼簡單!

嚐試一下

你能寫一個讓場景通過的calc.rb實現嗎?記住,在目前階段,我們隻需滿足一個單獨的場景,因此,一個非常簡單的方案就能解決該問題。

最後更新:2017-06-05 12:01:57

  上一篇:go  《Cucumber:行為驅動開發指南》——2.8 讓測試通過
  下一篇:go  怎麼做網站SEO優化排名效果才更好