开发者

Expectation for find not working, but expectation for find_by_id is

开发者 https://www.devze.com 2023-01-05 21:16 出处:网络
I have this controller code: # GET /cardsets/1 def show @cardset = current_user.cardsets.find_by_id(params[:id])

I have this controller code:

# GET /cardsets/1
def show
  @cardset = current_user.cardsets.find_by_id(params[:id])
end开发者_运维知识库

And this RSpec test code (mocking with Mocha):

# GET Show
context "on get to show" do
  it "should assign cardset" do
    @cardset = Factory(:cardset)
    @profile = @cardset.profile

    @profile.cardsets.expects(:find).once.returns(@cardset)
    get :show, :id => @cardset.id
    assigns[:cardset].should_not be_nil
  end
end

This test fails with:

2)
Mocha::ExpectationError in 'CardsetsController for a logged in user on get to show should assign cardset'
not all expectations were satisfied
unsatisfied expectations:
- expected exactly once, not yet invoked: [#<Cardset:0x1032bb660>].find(any_parameters)
satisfied expectations:
- allowed any number of times, not yet invoked: ApplicationController.require_user(any_parameters)
- allowed any number of times, already invoked twice:     #<CardsetsController:0x10336c578>.current_user(any_parameters)

If I change the expectation to:

@profile.cardsets.expects(:find_by_id).once.returns(@cardset)

Then the test passes, why will this pass with find_by_id and not find?


I think this is because find and find_by_id are actually different messages. Your controller uses find_by_id, but you are setting the message expectation to look for find.

0

精彩评论

暂无评论...
验证码 换一张
取 消