2010-12-31 10 views
40

Ésta es la configuración:constante no inicializado en Tareas Rake

nuevos carriles aplicación, a continuación, poner esto en test_rake.rake lib/tareas: hello_class.rb

task :testclass do 
    HelloClass.hello 
end` 

Poner en app/models, o en lib/con esta línea: config.autoload_paths += %W(#{config.root}/lib) añadió a config.rb

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

testclass rastrillo da este error:

/Users/name/.rvm/gems/[email protected]/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/[email protected]/gems/rake-0.8.7/lib/rake.rb:636:in `call' 
/Users/name/.rvm/gems/[email protected]/gems/rake-0.8.7/lib/rake.rb:636:in `block in execute' 
/Users/name/.rvm/gems/[email protected]/gems/rake-0.8.7/lib/rake.rb:631:in `each' 
/Users/name/.rvm/gems/[email protected]/gems/rake-0.8.7/lib/rake.rb:631:in `execute' 
/Users/name/.rvm/gems/[email protected]/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/[email protected]/gems/rake-0.8.7/lib/rake.rb:590:in `invoke_with_call_chain' 
/Users/name/.rvm/gems/[email protected]/gems/rake-0.8.7/lib/rake.rb:583:in `invoke' 
/Users/name/.rvm/gems/[email protected]/gems/rake-0.8.7/lib/rake.rb:2051:in `invoke_task' 
/Users/name/.rvm/gems/[email protected]/gems/rake-0.8.7/lib/rake.rb:2029:in `block (2 levels) in top_level' 
/Users/name/.rvm/gems/[email protected]/gems/rake-0.8.7/lib/rake.rb:2029:in `each' 
/Users/name/.rvm/gems/[email protected]/gems/rake-0.8.7/lib/rake.rb:2029:in `block in top_level' 
/Users/name/.rvm/gems/[email protected]/gems/rake-0.8.7/lib/rake.rb:2068:in `standard_exception_handling' 
/Users/name/.rvm/gems/[email protected]/gems/rake-0.8.7/lib/rake.rb:2023:in `top_level' 
/Users/name/.rvm/gems/[email protected]/gems/rake-0.8.7/lib/rake.rb:2001:in `block in run' 
/Users/name/.rvm/gems/[email protected]/gems/rake-0.8.7/lib/rake.rb:2068:in `standard_exception_handling' 
/Users/name/.rvm/gems/[email protected]/gems/rake-0.8.7/lib/rake.rb:1998:in `run' 
/Users/name/.rvm/gems/ruby[email protected]/gems/rake-0.8.7/bin/rake:31:in `<top (required)>' 
/Users/name/.rvm/gems/[email protected]/bin/rake:19:in `load' 
/Users/name/.rvm/gems/[email protected]/bin/rake:19:in `<main>' 

¿Alguna idea? Desinstalé y reinstalé Ruby a través de RVM, eliminé/reconstruí el gemset, imprimí las rutas de autocarga para asegurarme de que hello_class.rb estaba en una de ellas ...

Puedo solicitar manualmente HelloClass desde el archivo .rake , pero luego tengo que hacer lo mismo para cualquier cosa de la que dependa HelloClass, por ejemplo, si HelloClass incluye HTTParty o la tarea configura un trabajo retrasado.

Cualquier ayuda sería increíble. ¡Gracias!

+0

Intención del código con 4 espacios para mantener el formato. – Heikki

Respuesta

102

Si inicia su tarea de rake con task :testclass => :environment do, su entorno Rails se cargará y estará disponible para la tarea.

+0

¡Oh hombre! Y estaba allí mismo en una de mis otras aplicaciones, también. ¡Gracias! –

11

Esto también ocurre cuando especifica correctamente la dependencia task :testclass => :environment do, pero ha habilitado threadsafe!.

Para solucionar este si habilitó threadsafe, hacer esto:

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

+1 su solución no funciona, pero su evaluación es correcta. Mi tarea funcionó si desactivé el hilo seguro ... Esto no es bueno ... esto es rails 3.2.17 –

+2

Al arreglar tu condicional, tiene que ser '.split ($ 0) [1]' –

+0

Para mí esto solo apareció en Production, funcionó bien en dev –

Cuestiones relacionadas