Невозможно запустить factory_girl под рельсами 3.0.5, неожиданно tCONSTANT - PullRequest
10 голосов
/ 14 марта 2011

Это мой конфиг Gemfile:

group :development, :test do
    gem 'rspec-rails'
    gem 'factory_girl', '~>2.0.0.beta1'
    gem 'factory_girl_rails', :git => 'https://github.com/thoughtbot/factory_girl_rails.git', :tag => 'v1.1.beta1'
end

Это мой spec_helper.rb:

# This file is copied to spec/ when you run 'rails generate rspec:install'
ENV["RAILS_ENV"] ||= 'test'
require File.expand_path("../../config/environment", __FILE__)
require 'rspec/rails'

require "factory_girl"

# Requires supporting ruby files with custom matchers and macros, etc,
# in spec/support/ and its subdirectories.
Dir[Rails.root.join("spec/support/**/*.rb")].each {|f| require f}
Dir[Rails.root.join("spec/factories/**/*.rb")].each {|f| require f}

Я добавил папку factories в LOAD_PATH, потому что я хочу хранить их в отдельной папке.

Это мой factories.rb файл:

требуется File.expand_path (File.dirname ( FILE ) + '../../spec_helper')

Factory.define(:user) do |f|
  f.country("China")
  ... other attributes here
end

Когда я запускаю тесты, используя rake spec:models, я получаю это:

spec/factories/factories.rb:1: syntax error, unexpected tCONSTANT, expecting $end

Я вижу, что это происходит из factory_girl find_definitions метода. Я пытался вызвать это сам, из spec_helper, но это ничего не меняет. Вот часть трассировки стека:

** Invoke spec:models (first_time)
** Invoke db:test:prepare (first_time)
** Invoke db:abort_if_pending_migrations (first_time)
** Invoke environment (first_time)
** Execute environment
rake aborted!

    C:/rails/rcproj/spec/factories/factories.rb:1: syntax error, unexpected tCONSTANT, expecting
    $end
            f.count...er) do |f|
                                  ^
    C:/Ruby187/lib/ruby/gems/1.8/gems/activesupport-3.0.5/lib/active_support/dependencies.rb:239:in `req
    uire'
    C:/Ruby187/lib/ruby/gems/1.8/gems/activesupport-3.0.5/lib/active_support/dependencies.rb:239:in `req
    uire'
    C:/Ruby187/lib/ruby/gems/1.8/gems/activesupport-3.0.5/lib/active_support/dependencies.rb:225:in `loa
    d_dependency'
    C:/Ruby187/lib/ruby/gems/1.8/gems/activesupport-3.0.5/lib/active_support/dependencies.rb:596:in `new
    _constants_in'
    C:/Ruby187/lib/ruby/gems/1.8/gems/activesupport-3.0.5/lib/active_support/dependencies.rb:225:in `loa
    d_dependency'
    C:/Ruby187/lib/ruby/gems/1.8/gems/activesupport-3.0.5/lib/active_support/dependencies.rb:239:in `req
    uire'
    C:/Ruby187/lib/ruby/gems/1.8/gems/factory_girl-2.0.0.beta2/lib/factory_girl/find_definitions.rb:20:i
    n `find_definitions'
    C:/Ruby187/lib/ruby/gems/1.8/gems/factory_girl-2.0.0.beta2/lib/factory_girl/find_definitions.rb:19:i
    n `each'
    C:/Ruby187/lib/ruby/gems/1.8/gems/factory_girl-2.0.0.beta2/lib/factory_girl/find_definitions.rb:19:i

Ответы [ 2 ]

26 голосов
/ 14 марта 2011

Я думаю, что проблема связана с загрузкой вашего завода.Просто запишите это в свой файл test_helper.rb

   require 'factory_girl'
   Dir.glob(File.dirname(__FILE__) + "/factories/*").each do |factory|
     require factory
   end

   OR

   require 'factory_girl'
   FactoryGirl.find_definitions
6 голосов
/ 13 октября 2011

У меня была та же проблема, но оказалось, что я просто назвал свой файл неверно (factories.rb.rb, спасибо Netbeans).Однако я обнаружил несколько вещей, которые были бы полезны для этой страницы.

  1. Со страницы начала работы .Фабричная девушка должна автоматически загружать следующие файлы, если они существуют:

    test/factories.rb
    spec/factories.rb
    test/factories/*.rb
    spec/factories/*.rb
    

    Помещение в test_helper.rb следующего кода может привести к двойной загрузке:

    require 'factory_girl' Factory.find_definitions

    Это вызвало у меня ошибку `add_as': Already defined: <factory name>.

  2. Драгоценный камень factory_girl_rails автоматически загружает factory_girl.Это не нужно, но, похоже, не имеет побочных эффектов.

  3. Я обнаружил, что синтаксис FactoryGirl довольно сильно изменился с тех пор, как я впервые узнал об этом в марте 2011 года. I очень рекомендую всем заглянуть на стартовую страницу, чтобы увидеть некоторые изменения.

...