2012-07-10 47 views
1

我想额外的参数传递到一个RSpec测试,因为这样(额外PARAMATERS是两个数组,guest_value和bar_value):将参数传递给一个RSpec测试

 it "should create an outing" do 
      lambda do 
       post :create, :outing => FactoryGirl.attributes_for(:outing), :guest_value => [55,66], :bar_value => [66,77] 
      end.should change(Outing, :count).by(1) 
     end 

但是,我的测试完全忽略他们,好像他们甚至不在那里。

另外,语法:

   post :create, :outing => { FactoryGirl.attributes_for(:outing), :guest_value => [55,66], :bar_value => [66,77] } 

踢了一个错误:

NoMethodError: 
    undefined method `each' for nil:NilClass 

这是我的控制器代码的结果:

def create 
@outing = Outing.new(params[:outing]) 

@outing.user_id = @user.id 

if @outing.save 

    params[:guestvalue].each do |guest_id| 
     @outing.add_guest(guest_id) 
    end 

    params[:barvalue].each do |bar_id| 
     @outing.add_bar(bar_id) 
    end 

    TimeRange.create(:element_id => @outing.id, :element_type => 'outing', :start_time => params[:day][:start_time], :end_time => params[:day][:end_time]) 

    flash[:notice] = "Outing created successfully!" 

    redirect_to @outing 
else 
    flash[:notice] = "Error creating outing!" 
    @outing = Outing.new 
    render(new_outing_path) 
end 

+1

不能是你的电话':guest_value'和':bar_value',而你正在检查'PARAMS [:guestvalue]'和'PARAMS [:barvalue]'(无下划线),可它? – DVG 2012-07-10 00:53:47

回答

2

井你绝对是你的d命令的花括号来做你想做的事(把数组传递给factorygirl函数)。发布错误,也许我可以帮助更多?

里根

+0

我已经添加了更多我的代码。希望它有帮助。 – 2012-07-10 00:47:44

+0

':barvalue'或'guestvalue'没有方法'.each',我假设这是因为在测试中你将它们命名为':bar_value'和':guest_value'。希望有帮助 – reagan 2012-07-10 00:52:47

+0

废话...这是做到了。谢谢。 – 2012-07-10 00:54:44