Должны ли совпадения have_many с пользовательским именем отношения

Как проверить это отношение ActiveRecord, используяShoulda matchers?

модели
class User < ActiveRecord::Base
  has_many :articles
end

class Article < ActiveRecord::Base
  belongs_to :author, class_name: 'User'
end
Тестовое задание
describe User do
  it { should have_many(:articles) }
end

Я получаю следующую ошибку:

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)>'

Так что, очевидно, ожидается, что поле отношения будет названоuser_id из-за имени класса пользователя. Я ожидаю, что должен быть какой-то метод тестирования, который можно использовать для переопределения этого ожидания, как

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

Но я не могу найти ничего подобного. Я что-то упускаю из виду?

Ответы на вопрос(1)

Ваш ответ на вопрос