Shoulda matchers have_many with custom relation name

試著忘記壹切 提交于 2019-12-06 03:40:17

问题


How do I test this ActiveRecord relation using shoulda matchers?

Models

class User < ActiveRecord::Base
  has_many :articles
end

class Article < ActiveRecord::Base
  belongs_to :author, class_name: 'User'
end

Test

describe User do
  it { should have_many(:articles) }
end

I'm getting the following error:

1) User should have many articles
     Failure/Error: it { should have_many(:articles) }
       Expected User to have a has_many association called articles (Article does not have a user_id foreign key.)
     # ./spec/models/user_spec.rb:4:in `block (2 levels) in <top (required)>'

So it obviously expects relation field to be named user_id because of User class name. I expect there has to be some test method that can be used to override this expectation like

it { should have_many(:articles).as(:owner) }

But I can't find anything like it. Am I missing something obvious?


回答1:


shoulda matchers includes a .with_foreign_key() option.

https://github.com/thoughtbot/shoulda-matchers#have_many

So in your example:

describe User do
  it { should have_many(:articles).with_foreign_key('author_id') }
end

Which is how your model should, I believe:

class User < ActiveRecord::Base
  has_many :articles, foreign_key: "author_id"
end


来源:https://stackoverflow.com/questions/21657906/shoulda-matchers-have-many-with-custom-relation-name

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!