неопределенный метод `each 'в сценарии factory_girl / rspec2 - PullRequest
5 голосов
/ 21 сентября 2010

Я пытаюсь создать сообщение, связанное с голосованием. Так, чтобы Post.votes генерировал голоса, связанные с ним.

Factory.define :voted_post, :parent => :post, :class => Post do |p|
  p.association :votes, :factory => :vote
end

И мой rspec2 относительно прост:

describe "vote scores" do
  it "should show me the total vote score" do
    @post = Factory(:voted_post)
    @post.vote_score.should == 1
  end
end

Так почему бы вернуть эту ошибку:

Failures:
   1) Post vote scores should show me the total vote score
     Failure/Error: @post = Factory(:voted_post)
     undefined method `each' for #<Vote:0x105819948>

ruby ​​1.8.7 (2009-06-12 patchlevel 174) [universal-darwin10.0]

Rails 3.0.0

Ответы [ 2 ]

12 голосов
/ 21 сентября 2010
Factory.define :voted_post, :parent => :post, :class => Post do |p|
  p.association :votes, :factory => :vote
end

Это то же самое, что пытаться пойти

some_voted_post.votes = Factory(:vote)

Обычно вы пытаетесь назначить один голос в виде массива.

EDIT

У вас может быть массив, содержащий один голос, но вы не можете просто иметь один голос.

Это разница между:

some_voted_post.votes = Factory(:vote)

и

some_voted_post.votes = [Factory(:vote)]

Первый не является массивом и, следовательно, не работает, последний является массивом.

5 голосов
/ 28 июля 2011

Если вы хотите назначить ассоциацию has_many, которая ожидает массив, а не одно значение, вы должны использовать длинную форму:

Factory.define :voted_post, :parent => :post, :class => Post do |p|
  p.votes { |vote| [vote.association(:vote)] }
end

И инкапсулировать создание ассоциации с [], чтобы гарантировать, что массив будет возвращен

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...