是否有更好的方法来格式化此测试以使其更具可读性?
expect {
within '.foo' do
click_link 'Delete'
end
}.to change {Foo.count}.by 1
期待do...end
有效,但更加丑陋......
答案 0 :(得分:8)
也许是这样的?
expected = expect do
within '.foo' do
click_link 'Delete'
end
end
expected.to change { Foo.count }.by 1
不完全漂亮,但减少了一些线路噪音。
答案 1 :(得分:4)
由于将所有内容放在花括号中并且在一行上会太长,我会这样写:
expect do
within(".foo") { click_link "Delete" }
end.to change { Foo.count }.by 1
更新: 没有经过测试,但这也应该有效:
click_delete_link = lambda { within(".foo") { click_link "Delete" } }
expect { click_delete_link }.to change { Foo.count }.by 1
但我仍然更喜欢第一个版本:)