我正在尝试检查某个方法是否未在after_update
回调中调用。
我正在做:
class Foo
def self.call; end
end
def Model < ActiveRecord::Base
after_update :do_something
def do_something
return unless title_changed?
Foo.call
end
end
在测试中它是这样的:
test 'Foo.new.bar is invoked' do
mock = Minitest::mock.new
mock.expect :call, nil
Foo.stub(:call) { update_record_to_fire_callback }
mock.verify
end
它通过得很漂亮,但是现在我正试图做相反的事情,但是没有运气,因为我不知道该怎么做。如果我这样做了,assert_not mock.verify
无论如何,Minitest都会抱怨要执行该方法。
或者也许还有其他方法可以检查方法是否未调用?该方法将执行昂贵的请求,因此,我想避免这种情况。
我正在使用Rails 5,遗憾的是Minitest。我愿意添加可以在这些版本上使用的所有宝石。
答案 0 :(得分:1)
由于您愿意添加宝石,因此mocha非常适合此操作。添加宝石,然后使用摩卡咖啡的Expectation#never。然后,您的测试如下所示:
test 'Foo.new.bar is not invoked' do
model = Model.new
Foo.expects(:call).never
model.update!(not_the_title: 'value')
end
答案 1 :(得分:0)
最简单的方法是对要确保不会被调用的方法加桩,并引发错误。
class ModelTest < ActiveSupport::TestCase
test "does not call Foo.call when title is not changed" do
model = Model.new
refute model.title_changed?
Foo.stub(:call, -> { raise "Foo was called!" }) do
model.title = "something new"
end
assert model.title_changed?
end
end
没有断言可以检查未明确引发错误。 Rails确实有assert_nothing_raised
,但有Minitest does not。您可以根据需要添加它。
class ModelTest < ActiveSupport::TestCase
test "does not call Foo.call when title is not changed" do
model = Model.new
refute model.title_changed?
Foo.stub(:call, -> { raise "Foo was called!" }) do
assert_nothing_raised do
model.title = "something new"
end
end
assert model.title_changed?
end
end