Неинициализированная константа в задачах Rake - PullRequest
41 голосов
/ 01 января 2011

Вот настройка:

Новое приложение Rails, затем поместите этот test_rake.rake в lib / tasks:

task :testclass do
  HelloClass.hello
end`

Поместите hello_class.rb в app / models или в lib /с этой строкой: config.autoload_paths += %W(#{config.root}/lib) добавлено в config.rb

class HelloClass
  def self.hello
    puts 'hello_class'
  end
end

rake testclass выдает эту ошибку:

/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:2503:in `const_missing'
/Users/name/Sites/Rails/indexapp/lib/tasks/test_class.rake:5:in `block (2 levels) in <top (required)>'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:636:in `call'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:636:in `block in execute'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:631:in `each'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:631:in `execute'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:597:in `block in invoke_with_call_chain'
/Users/name/.rvm/rubies/ruby-1.9.2-p0/lib/ruby/1.9.1/monitor.rb:201:in `mon_synchronize'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:590:in `invoke_with_call_chain'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:583:in `invoke'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:2051:in `invoke_task'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:2029:in `block (2 levels) in top_level'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:2029:in `each'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:2029:in `block in top_level'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:2068:in `standard_exception_handling'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:2023:in `top_level'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:2001:in `block in run'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:2068:in `standard_exception_handling'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/lib/rake.rb:1998:in `run'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/gems/rake-0.8.7/bin/rake:31:in `<top (required)>'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/bin/rake:19:in `load'
/Users/name/.rvm/gems/ruby-1.9.2-p0@global/bin/rake:19:in `<main>'

Есть идеи?Я удалил и переустановил Ruby через RVM, удалил / перестроил gemset, распечатал пути автозагрузки, чтобы убедиться, что hello_class.rb был в одном из них ...

Я могу вручную требовать HelloClass изнутри.rake file, но затем я должен сделать то же самое для всего, что зависит от HelloClass - скажем, например, если HelloClass включает HTTParty или задача устанавливает отложенное задание.

Любая помощь будет потрясающей.Спасибо!

Ответы [ 2 ]

105 голосов
/ 01 января 2011

Если вы запускаете задачу rake с task :testclass => :environment do, ваша среда Rails будет загружена и доступна для задачи.

11 голосов
/ 19 февраля 2014

Это также происходит, когда вы правильно указали зависимость task :testclass => :environment do, но включили threadsafe!.

Чтобы исправить это, если вы включили threadsafe, сделайте следующее:

   # in your application.rb or environment file:
   #
   config.threadsafe! unless File.split($0).last == 'rake' # unless this is a rake task
...