我已经尝试过这段代码,但它引发了错误:NameError: uninitialized constant RSpec::Mocks::Mock
RSpec::Mocks::Mock.stub(:i18n_scope).and_return(:activerecord)
model = double(:model, errors: double(:errors, full_messages: []))
ActiveRecord::RecordInvalid.new(model)
我怎样才能存根i18n_scope
?
要回答你的问题,你必须存根RSpec::Mocks::Double
因为这是您实际传递给 ActiveRecord::RecordInvalid 的实例的类。但是,这行不通,因为RSpec::Mocks::Double
不执行.i18n_scope
。所以,我所做的(我讨厌它)就是给RSpec::Mocks::Double
具有虚拟方法的类。
it "does something cool" do
foo = MyClass.new
class RSpec::Mocks::Double
def self.i18n_scope
:activerecord
end
end
error_double = double(:model, errors: double(:errors,full_messages: ["blah"]))
expect(foo).to receive(:bar).and_raise(ActiveRecord::RecordInvalid, error_double)
...
end
但是有一种更好的方法可以利用块参数来做到这一点:
it "does something cool" do
foo = MyClass.new
expect(foo).to receive(:bar) do |instance|
instance.errors.add(:base, "invalid error")
raise(ActiveRecord::RecordInvalid, instance)
end
...
end
这样,您的测试就更接近您的应用程序数据/逻辑,而不是黑客 RSpec。
这对于控制器测试非常有效,我正在从 #update! 引发的特定错误中拯救出来。特定情况下的方法。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)