Ошибка кодирования начальных данных Faker

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

У меня есть несколько проблем. Мой код ниже загружает одного пользователя и один список для этого пользователя, но не может загрузить элементы для списка. Моя мысль заключалась в том, чтобы сначала заставить это работать, но в конце концов я хотел иметь 5 пользователей, каждый с одним списком и 15 элементами в каждом списке, созданными фейкером. Любая помощь приветствуется.

require 'faker'

# Create an admin user
admin = User.new(
  name:     'Admin User',
  email:    '[email protected]',
  password: 'helloworld'
)
admin.skip_confirmation!
admin.save!

# Create List
1.times do
  List.create(
    user: admin,
    title: 'Admin List'
  )
end

# Create Items
15.times do
  Item.create(
    list: 'Admin List',
    name: Faker::Company.bs
  )
end

puts "Seed finished"
puts "#{User.count} users created"
puts "#{List.count} lists created"
puts "#{Item.count} items created"

это полная ошибка

heidi-golds-imac:blocitoff dale$ rake db:seed
rake aborted!
ActiveRecord::AssociationTypeMismatch: List(#70281090559180) expected, got    String(#70281054267240)
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord-4.2.0/lib/active_record/associations/association.rb:216:in  `raise_on_type_mismatch!'
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord-4.2.0/lib/active_record/associations/belongs_to_association.rb:12:in `replace'
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord-4.2.0/lib/active_record/associations/singular_association.rb:17:in `writer'
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord-  4.2.0/lib/active_record/associations/builder/association.rb:123:in `list='
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord-4.2.0/lib/active_record/attribute_assignment.rb:54:in `public_send'
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord-4.2.0/lib/active_record/attribute_assignment.rb:54:in `_assign_attribute'
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord- 4.2.0/lib/active_record/attribute_assignment.rb:41:in `block in    assign_attributes'
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord- 4.2.0/lib/active_record/attribute_assignment.rb:35:in `each'
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord- 4.2.0/lib/active_record/attribute_assignment.rb:35:in `assign_attributes'
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord-4.2.0/lib/active_record/core.rb:557:in `init_attributes'
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord-4.2.0/lib/active_record/core.rb:280:in `initialize'
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord-4.2.0/lib/active_record/inheritance.rb:61:in `new'
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord-4.2.0/lib/active_record/inheritance.rb:61:in `new'
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord-4.2.0/lib/active_record/persistence.rb:33:in `create'
/Users/dale/code/blocitoff/db/seeds.rb:22:in `block in <top (required)>'
/Users/dale/code/blocitoff/db/seeds.rb:21:in `times'
/Users/dale/code/blocitoff/db/seeds.rb:21:in `<top (required)>'
/usr/local/rvm/gems/ruby-2.2.0/gems/activesupport-4.2.0/lib/active_support/dependencies.rb:268:in `load'
/usr/local/rvm/gems/ruby-2.2.0/gems/activesupport-4.2.0/lib/active_support/dependencies.rb:268:in `block in load'
/usr/local/rvm/gems/ruby-2.2.0/gems/activesupport-4.2.0/lib/active_support/dependencies.rb:240:in `load_dependency'
/usr/local/rvm/gems/ruby-2.2.0/gems/activesupport-4.2.0/lib/active_support/dependencies.rb:268:in `load'
/usr/local/rvm/gems/ruby-2.2.0/gems/railties- 4.2.0/lib/rails/engine.rb:547:in `load_seed'
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord- 4.2.0/lib/active_record/tasks/database_tasks.rb:250:in `load_seed'
/usr/local/rvm/gems/ruby-2.2.0/gems/activerecord- 4.2.0/lib/active_record/railties/databases.rake:180:in `block (2 levels) in <top  (required)>'
Tasks: TOP => db:seed
(See full trace by running task with --trace)

Контроллер предметов

class ItemsController < ApplicationController
  before_action :find_list

  def create
    @item = @list.items.build(params.require(:item).permit(:name))

    unless @item.save
      flash[:error] = "There was an error. Please try again."
    end

    redirect_to @list
  end

  private

  def find_list
    @list = List.find(params[:list_id])
  end
end

Контроллер списков

 class ListsController < ApplicationController

 before_action :authenticate_user! # users must be signed in before any     lists_controller method

  def show
    @list = current_user.list
  end

  def new
    @list = List.new
  end

  def create
     @list = current_user.build_list(params.require(:list).permit(:title,  :body))
     if @list.save
       flash[:notice] = "List was saved."
       redirect_to @list
     else
       flash[:error] = "There was an error. Please try again."
       render :new
     end
   end

  def edit
    @list = List.find(params[:id])
  end

  def update
     @list = List.find(params[:id])
     if @list.update_attributes(params.require(:list).permit(:title, :body))
       flash[:notice] = "List was updated."
       redirect_to @list
     else
       flash[:error] = "There was an error. Please try again."
       render :edit
     end
   end
end

person Dale Brown    schedule 05.02.2015    source источник


Ответы (2)


Проблема в том, что вы назначаете список элементу по имени, а не по ссылке. В блоке кода, где вы создаете свой список, вам нужно присвоить его переменной:

список = Список.создать...,

Затем, при создании вашего элемента, вам нужно сделать это:

Item.create(список: список....

Вы использовали заголовок списка, где он искал объект списка.

person Beck    schedule 05.02.2015

Попробуйте исправить следующий код:

# Create Items
15.times do
  Item.create(
    list: 'Admin List'
    name: Faker::Company.bs
  )
end

Просто добавьте запятую после списка: «Список администраторов». Если это не решит проблему, опубликуйте полное сообщение об ошибке и укажите строку, в которой вы получаете сообщение об ошибке.

person Deepesh    schedule 05.02.2015
comment
Запятая не разрешилась, но теперь новая ошибка. Я отредактировал выше с запятой и полной новой ошибкой. - person Dale Brown; 05.02.2015
comment
Запятая устранила ошибку, которую вы разместили ранее. Это новая ошибка. Я предполагаю, что ваша строка 21 равна 1.time или 15.times, что выдает ошибку в .times. Так что попробуй изменить. Если строка отличается, укажите, какая строка является строкой 21. - person Deepesh; 05.02.2015