2011-12-26 5 views
8

Już od jakiegoś czasu prowadzę Guard for RSPEC i korzystam z gem growl_notify (2-3 miesiące), ale teraz nie mogę uzyskać guard do uruchamiania w którymkolwiek z moich projektów Rails 3.1.1. Zrobiłem kilka badań na temat samego błędu, ale nie mogłem wymyślić niczego rozstrzygającego (z wyjątkiem someone else ma ten sam problem).Rails 3.1.1 Guard-rspec nie może działać z powodu błędów Growla: OSERROR: -10000 WIADOMOŚĆ: Obsługa zdarzeń Apple nie powiodła się

Gemfile:

source 'http://rubygems.org' 

gem 'rails', '3.1.1' 

# Bundle edge Rails instead: 
# gem 'rails',  :git => 'git://github.com/rails/rails.git' 

# Gems used only for assets and not required 
# in production environments by default. 
group :assets do 
    gem 'sass-rails', '~> 3.1.4' 
    gem 'coffee-rails', '~> 3.1.1' 
    gem 'uglifier', '>= 1.0.3' 
end 

gem 'jquery-rails' 
gem 'spreadsheet' # Allows for reading/writing Excel files. We also need a CSV importer, but that can come later 
gem 'gmaps4rails' # Allows for Google Maps Pushpins/Markers/Places 
gem 'scoped_search' # For Searching 
gem "paperclip", :git => "git://github.com/thoughtbot/paperclip.git" # For File Uploads 

group :test, :development do 
    gem 'sqlite3' 
    gem 'turn', '<0.8.3' 
    gem 'rspec-rails' 
    gem 'capybara' 
    gem 'guard-rspec' 
    gem 'growl_notify' 
    gem 'launchy' 
    gem 'capistrano' #You don't want Capistrano on the production side (I think) 
end 

group :production do 
    gem 'pg' #use postgres for database installation as the database 
end 

Błąd:

[email protected]:~/development/rails/tasks$ guard 
/Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/rb-appscript-0.6.1/lib/appscript.rb:542:in `_send_command': CommandError (Appscript::CommandError) 
     OSERROR: -10000 
     MESSAGE: Apple event handler failed. 
     COMMAND: app("/Library/PreferencePanes/Growl.prefPane/Contents/Resources/GrowlHelperApp.app").register({:all_notifications=>["success", "pending", "failed", "notify"], :as_application=>"Guard", :default_notifications=>"notify"}) 
    from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/rb-appscript-0.6.1/lib/appscript.rb:642:in `method_missing' 
    from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/growl_notify-0.0.3/lib/growl_notify.rb:29:in `register' 
    from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/growl_notify-0.0.3/lib/growl_notify.rb:19:in `config' 
    from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/guard-0.9.4/lib/guard/notifiers/growl_notify.rb:42:in `available?' 
from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/guard- 0.9.4/lib/guard/notifier.rb:117:in `add_notification' 
    from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/guard-0.9.4/lib/guard/notifier.rb:154:in `block in auto_detect_notification' 
    from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/guard-0.9.4/lib/guard/notifier.rb:154:in `each' 
    from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/guard-0.9.4/lib/guard/notifier.rb:154:in `any?' 
    from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/guard-0.9.4/lib/guard/notifier.rb:154:in `auto_detect_notification' 
from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/guard- 0.9.4/lib/guard/notifier.rb:80:in `turn_on' 
    from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/guard-0.9.4/lib/guard.rb:184:in `start' 
    from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/guard-0.9.4/lib/guard/cli.rb:74:in `start' 
    from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/thor-0.14.6/lib/thor/task.rb:22:in `run' 
from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/thor- 0.14.6/lib/thor/invocation.rb:118:in `invoke_task' 
from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/thor- 0.14.6/lib/thor.rb:263:in `dispatch' 
    from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/thor-0.14.6/lib/thor/base.rb:389:in `start' 
    from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/gems/guard-0.9.4/bin/guard:6:in `<top (required)>' 
    from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/bin/guard:19:in `load' 
    from /Users/Thomas/.rvm/gems/ruby-1.9.2-p290/bin/guard:19:in `<main>' 
+0

Po prostu wpadłem na ten sam numer – keruilin

Odpowiedz

5

To wydaje się być wersja niedopasowanie pomiędzy Growl i growl_notify. growl_notify 0.0.3 zmieniono nazwę aplikacji Growl, co blisko, jak mogę powiedzieć zmieniony z Growl 1.3 (Lion tylko)

Uważam, że przekłada się na:

  • użytku growl_notify 0.0.2 dla Growl < 1.3
  • użycie growl_notify 0.0.3 dla Growl> = 1,3
  • użycie Growl gem (co zrobiłem)
+0

Nie zapomnij odinstalować innych klejnotów (np. Usuń groźny_notify, jeśli używasz grosza). – Lenart

7

Oto co pracował dla mnie. Dwie rzeczy:

Najpierw Guard 0.10.x. wymaga Growl> = 1,3. Zainstaluj Growl 1.3 z App Store (te recenzje są naprawdę złe, ale nie miałem żadnych problemów).

Po drugie, nowe wersje Guard zalecają ruby_gntp. Po prostu zamień gem 'growl_notify' na gem 'ruby_gntp'.

+0

Idź klejnotem "ruby_gntp", jeśli jesteś na lampartie śnieżnym –

Powiązane problemy