2010-12-31 5 views
40

Hier ist das Setup:Uninitialized Konstante in Rake Aufgaben

New Rails-Anwendung, dann setzen Sie diese test_rake.rake in lib/Aufgaben:

task :testclass do 
    HelloClass.hello 
end` 

Put hello_class.rb in app/models oder in lib/mit dieser Zeile: config.autoload_paths += %W(#{config.root}/lib) hinzugefügt

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

Rake Testklasse gibt diesen Fehler zu config.rb:

/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/[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>' 

Irgendwelche Ideen? Ich habe Ruby über RVM deinstalliert und neu installiert, das Gemset gelöscht/neu erstellt, die Autoloadpfade ausgedruckt, um sicherzustellen, dass hello_class.rb in einem von ihnen war ...

Ich kann HelloClass manuell in der .rake-Datei anfordern , aber dann muss ich das Gleiche für alles tun, von dem HelloClass abhängt - sagen wir zum Beispiel, ob HelloClass HTTParty enthält oder die Aufgabe einen verzögerten Job einrichtet.

Jede Hilfe wäre genial. Vielen Dank!

+0

den Code mit 4 Leerzeichen Beabsichtigen die Formatierung zu halten. – Heikki

Antwort

102

Wenn Sie Ihre Rake-Task mit task :testclass => :environment do starten, wird Ihre Rails-Umgebung geladen und für die Task verfügbar.

+0

Oh Mann! Und es war genau dort in einer meiner anderen Apps auch. Vielen Dank! –

11

Dies geschieht auch, wenn Sie die Abhängigkeit task :testclass => :environment do korrekt angeben, aber threadsafe! aktiviert haben.

Um dies zu beheben, wenn Sie threadsafe aktiviert ist, dies zu tun:

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

+1 Ihre Lösung funktioniert nicht, aber Ihre Einschätzung ist korrekt. Meine Aufgabe hat funktioniert, wenn ich Thread Safe deaktiviert habe .. Dies ist nicht gut .... das ist Rails 3.2.17 –

+2

Fixing Ihre Bedingung, es muss '.split ($ 0) [1]' –

+0

Für mich dies nur angezeigt auf Produktion, es funktionierte gut auf dev –

Verwandte Themen