在学习rspec语法时,我注意到这段代码可以工作:
context "given a bad list of players" do
let(:bad_players) { {} }
it "fails to create given a bad player list" do
expect{ Team.new("Random", bad_players) }.to raise_error
end
end但这段代码并没有:
context "given a bad list of players" do
let(:bad_players) { {} }
it "fails to create given a bad player list" do
expect( Team.new("Random", bad_players) ).to raise_error
end
end它给了我这个错误:
Team given a bad list of players fails to create given a bad player list
Failure/Error: expect( Team.new("Random", bad_players) ).to raise_error
Exception:
Exception
# ./lib/team.rb:6:in `initialize'
# ./spec/team_spec.rb:23:in `new'
# ./spec/team_spec.rb:23:in `block (3 levels) in <top (required)>'我的问题是:
我也在寻找rules关于何时使用其中一种而另一种。
还有一个相同但相反的结果的例子,这段代码可以工作:
it "has a list of players" do
expect(Team.new("Random").players).to be_kind_of Array
end 但是这段代码失败了
it "has a list of players" do
expect{ Team.new("Random").players }.to be_kind_of Array
end在这种情况下,我遇到的错误是:
Failure/Error: expect{ Team.new("Random").players }.to be_kind_of Array
expected #<Proc:0x007fbbbab29580@/Users/amiterandole/Documents/current/ruby_sandbox/tdd-ruby/spec/team_spec.rb:9> to be a kind of Array
# ./spec/team_spec.rb:9:in `block (2 levels) in <top (required)>'我正在测试的课程如下:
class Team
attr_reader :name, :players
def initialize(name, players = [])
raise Exception unless players.is_a? Array
@name = name
@players = players
end
end发布于 2013-11-13 19:09:36
如上文所述:
expect(4).to eq(4)这是专门测试您作为该方法的参数传入的值。当您尝试测试引发的错误时,您做同样的事情:
expect(raise "fail!").to raise_error您的论点将立即评估,该异常将被抛出,您的测试将在那里爆炸。
但是,当使用块(这是基本的ruby)时,块内容不会立即执行--它的执行取决于您正在调用的方法(在本例中,expect方法处理何时执行块):
expect{raise "fail!"}.to raise_error我们可以查看一个可能处理此行为的示例方法:
def expect(val=nil)
if block_given?
begin
yield
rescue
puts "Your block raised an error!"
end
else
puts "The value under test is #{val}"
end
end您可以在这里看到,手动恢复错误的是expect方法,这样它就可以测试是否引发错误,等等。yield是ruby方法执行传递给该方法的任何块的方式。
发布于 2013-11-13 17:59:23
在第一种情况下,当您将一个块传递给expect时,要到评估结果的时候才会执行该块,此时RSpec代码可以捕获引发的任何错误,并根据期望检查它。
在第二种情况下,在计算expect的参数时会出现错误,因此expect代码没有机会参与其中。
至于规则,如果您试图测试行为(例如,引发错误、更改某些值),则可以传递一个块或一个Proc。否则,您将传递一个“常规”参数,在这种情况下,该参数的值就是所测试的值。
https://stackoverflow.com/questions/19960831
复制相似问题