rspec 模拟:验证其中的期望“应该”方法?
我正在尝试使用 rspec 的模拟来设置我可以在“应该”方法中验证的期望...但我不知道如何做到这一点...当我在模拟上调用 .should_receive 方法时,它before:all 方法退出后立即验证预期的调用。
这是一个小例子:
describe Foo, "when doing something" do
before :all do
Bar.should_recieve(:baz)
foo = Foo.new
foo.create_a_Bar_and_call_baz
end
it "should call the bar method" do
# ??? what do i do here?
end
end
我如何验证“它“应该””方法中的预期调用?我需要使用 mocha 或其他模拟框架而不是 rspec 的吗?或者 ???
I'm trying to use rspec's mocking to setup expectations that I can verify in the it "should" methods... but I don't know how to do this... when i call the .should_receive methods on the mock, it verifies the expected call as soon as the before :all method exits.
here's a small example:
describe Foo, "when doing something" do
before :all do
Bar.should_recieve(:baz)
foo = Foo.new
foo.create_a_Bar_and_call_baz
end
it "should call the bar method" do
# ??? what do i do here?
end
end
How can i verify the expected call in the 'it "should"' method? do i need to use mocha or another mocking framework instead of rspec's? or ???
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(5)
我将对此进行另一次打击,因为从最初的一组答案和回复中可以清楚地看出,您对要实现的目标存在一些困惑。让我知道这是否更接近您想要做的事情。
顺便说一句,虽然它有效,但我不太喜欢
Bar.stub!(:new)
模式;我通常更喜欢通过可选参数传递协作者,例如@it.frob!(@bar)
。当没有给出显式参数时(例如在生产代码中),可以默认协作者:def frob!(bar=Bar.new)
。这使得测试较少受内部实现的束缚。I'm going to take another whack at this, because it's clear from the initial set of answers and responses that there was some confusion about what you are trying to accomplish. Let me know if this is closer to what you are trying to do.
Incidentally, although it works I'm not a big fan of the
Bar.stub!(:new)
pattern; I usually prefer to pass collaborators in via optional arguments, e.g.@it.frob!(@bar)
. When not given an explicit argument (e.g. in the production code), the collaborator can be defaulted:def frob!(bar=Bar.new)
. This keeps the tests a little less bound to internal implementation.作为一般规则,您永远不应该将期望放在
before
块中。before
块用于设置在多个示例(it
块)之间共享的状态。将期望放在示例本身中。例如:我通常尝试让我的
describe
块描述特定的状态(例如describe Car,“给定一整罐汽油”
),而不是描述一个动作。As a general rule you should never put an expectation in a
before
block.before
blocks are for setting up state that is shared across several examples (it
blocks). Put the expectation in the example itself. E.g.:I generally try to have my
describe
block describe a particular state (e.g.describe Car, "given a full tank of gas"
), rather than describing an action.should_receive 方法用于设置模拟对象以在调用该方法时返回特定的内容。下面是一个示例:
通常,使用 BDD,您希望测试应用程序的行为。测试调用哪些方法来构建正确的行为是无关紧要的。如果有一天您决定删除 baz 方法,即使您的应用程序的行为没有改变,您也必须更新您的测试。
我认为你试图以一种不应该这样的方式使用 should_receive 。
The should_receive method is used to setup your mock object to return something specific when the method is called. Here's an example:
Typically, with BDD, you want to test the behavior of your app. Testing which methods were called in order to build the proper behavior is irrelevant. If one day you decide to remove the baz method, you'll have to update your tests even though the behavior of your app won't have changed.
I think you're trying to use should_receive in a way that it wasn't meant to work like.
我知道这是一个古老的对话,但以防万一有人仍然需要正确的答案,在这里我写了一个关于如何验证 rpec 模拟观察的示例:
干杯
I know this is an old conversation but just in case somebody still needed a right answer, here I write an example on how to validate rpec mocks spectations:
cheers
也许我看得太简单了,但是,您是否需要多次验证与 Bar 的交互?如果是这样,好吧,但我不确定。换句话说,您是否混合了上下文?
如果不是,那么它并不是真正的上下文,而是观察的一部分,这将使它自然地属于 it 块。
Maybe I'm looking at it simplistically, but, do you need to verify that interaction with Bar more than once? If so, ok, but I'm not sure. In other words, are you mixing contexts?
If not, then it's not really context so much as it's part of the observation, which would make it naturally belong to the it block.