У меня есть модуль, который включен в другой модуль, и оба они реализуют один и тот же метод. Я хотел бы заглушить метод включенного модуля, что-то вроде этого:
module M
def foo
:M
end
end
module A
class << self
include M
def foo
super
end
end
end
describe "trying to stub the included method" do
before { allow(M).to receive(:foo).and_return(:bar) }
it "should be stubbed when calling M" do
expect(M.foo).to eq :bar
end
it "should be stubbed when calling A" do
expect(A.foo).to eq :bar
end
end
Первый тест проходит, но второй выдает:
Failure/Error: expect(A.foo).to eq :bar
expected: :bar
got: :M
Почему в этом случае не работает заглушка? Есть ли другой способ добиться этого?
Спасибо!
-------------------------------------ОБНОВИТЬ------------ ----------------------
Спасибо! использование allow_any_instance_of(M) решило эту проблему. Мой следующий вопрос: что произойдет, если я использую prepend и не включаю? см. следующий код:
module M
def foo
super
end
end
module A
class << self
prepend M
def foo
:A
end
end
end
describe "trying to stub the included method" do
before { allow_any_instance_of(M).to receive(:foo).and_return(:bar) }
it "should be stubbed when calling A" do
expect(A.foo).to eq :bar
end
end
На этот раз использование allow_any_instance_of(M) приводит к бесконечному циклу. почему это?