ruby-on-rails – 使用Rspec测试“Post create”

我正在尝试用Rspec测试“Post create”动作.代码如下:
def valid_attributes
     {
    :zone => Flymgr::Zone.new(:countries => Flymgr::ZoneCountry.first,:name => 'USA',:description => 'USA Flight',:zipcodes => ''),:price => '100.00',:class => 'first',}
   end

   def valid_session
     {}
   end

   before(:each) do
       @request.env["devise.mapping"] = Devise.mappings[:admin]
       admin = FactoryGirl.create(:admin)
       sign_in admin                           
      end

describe "POST create" do
     describe "with valid params" do
       it "creates a new Flymgr::Rule" do
         expect {
           post :create,{:Flymgr_rule => valid_attributes}
         }.to change(Flymgr::Rule,:count).by(1)
       end

表单的必需属性之一是“区域”,这是一个下拉框,下拉列表的选项是使用不同的表单创建的.我不知道如何使用Rspec创建表单条目.如您所见,我试图从不同的控制器Flymgr :: Zone.new调用一个方法.我不认为这是有效的,它打破了我的考验.

谁能建议最好的方法来做到这一点?也许我应该使用FactoryGirl来创建区域和规则条目?

解决方法

你的请求参数hash有一个对象作为值:zone,当你发布它只是’to_s’-ed,这不太可能你想要的.

通常,最佳做法是使用factory girl构建对象,并使用attributes_for策略为post请求参数化其属性
What is the proper way to test ‘create’ controller actions?

您的问题是建议该关联是belongs_to,因此您只需要发布一个ID.请注意,目前,FactoryGirl不会为关联创建任何属性.如果规则的工厂定义负责区域关联,则可以使用此解决方法

FactoryGirl.build(:flymgr_rule).attributes

包括zone_id但是,您需要排除不需要的参数.
(“id”,“created_at”,“updated_at”等).

因此,您可能最好在您在有效的帖子请求中看到它的方式显式插入区域的参数哈希信息.

在factorygirl属性和关联上阅读此主题
https://github.com/thoughtbot/factory_girl/issues/359

相关文章

以下代码导致我的问题: class Foo def initialize(n=0) @n = n end attr_accessor :n d...
这是我的spec文件,当为上下文添加测试“而不是可单独更新用户余额”时,我得到以下错误. require 's...
我有一个拦截器:DevelopmentMailInterceptor和一个启动拦截器的inititializer setup_mail.rb. 但我想将...
例如,如果我有YAML文件 en: questions: new: 'New Question' other: recent: ...
我听说在RSpec中避免它,let,let !,指定,之前和主题是最佳做法. 关于让,让!之前,如果不使用这些,我该如...
我在Rails中使用MongoDB和mongo_mapper gem,项目足够大.有什么办法可以将数据从Mongoid迁移到 Postgres...