《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