Rspec any_instance should_receive应该收到以下消息,但没有

时间:2013-03-01 00:35:00

标签: ruby-on-rails rspec update-attributes

我遇到了一个针对rspec的脚手架测试的问题,其中any_instance.should_receive正在抛出一个错误:失败/错误:无法从backtrace中找到匹配的行        确切地说,一个实例应该收到以下消息但没有:update_attributes

Rspec代码,使用FactoryGirl和strong_parameters:

describe "PUT update" do
   describe "with valid params" do
     it "updates the requested acquisition" do
       puts "starting updates the requested acquisition"
       acquisition = create(:acquisition)
       # Assuming there are no other acquisitions in the database, this
       # specifies that the Acquisition created on the previous line
       # receives the :update_attributes message with whatever params are
       # submitted in the request.
       Acquisition.any_instance.should_receive(:update_attributes).with(:acquisition =>    {:person_id => '10'})
      puts "before the put "
       put :update, :id => acquisition.id, :acquisition => { :person_id => '10'}
       puts "ending the updates the requested acquisition"
     end   
  end
end

控制器代码:

def update
    @acquisition = Acquisition.find(params[:id])
    puts "acquisition is #{@acquisition.inspect}"
    respond_to do |format|
      if @acquisition.update_attributes!(acquisition_params)
        puts "updated the thing! #{@acquisition.inspect}"
        format.html { redirect_to(@acquisition, :notice => 'Acquisition was successfully updated.') }
        format.xml  { head :ok }
      else
        puts "failed to update the thing!"
        format.html { render :action => "edit" }
        format.xml  { render :xml => @acquisition.errors, :status => :unprocessable_entity }
      end
    end
  end

测试输出:

starting updates the requested acquisition
before the put
acquisition is #<Acquisition id: 502, sample_id: 7, person_id: 7, method: nil>
params is acqusition_params is {"person_id"=>"10"}
updated the thing! #<Acquisition id: 502, sample_id: 7, person_id: 10, method: nil>
ending the updates the requested acquisition
F

1) AcquisitionsController PUT update with valid params updates the requested acquisition
 Failure/Error: Unable to find matching line from backtrace
   Exactly one instance should have received the following message(s) but didn't: update_attributes

鉴于我在控制器中打印出更新的对象并且它是正确的,为什么测试失败?

谢谢!

1 个答案:

答案 0 :(得分:2)

这可能是您的粘贴中的拼写错误,但如果不是,则您的测试应测试是否收到update_attributes!,而不是update_attributes

Acquisition.any_instance.should_receive(:update_attributes!)