0

我正在构建一个 Rails 应用程序并使用 Spork/Guard/Rspec 进行测试。

我在 mac (10.6.8) 上——这是我正在使用的 gem:

gem "rspec-rails", "~> 2.12.1"   
gem "guard-rspec", "~> 2.3.3"   
gem "guard-spork", "~> 1.4.1"   
gem "spork", "~> 0.9.2"   
gem 'rb-fsevent', '~> 0.9.1', :require => false   
gem "growl", "~> 1.0.3"  
gem 'capybara', '1.1.2'

当我编辑路由文件时,它应该重新启动 spork 服务器,这是我的 Guardfile 中的行:

guard 'spork', :rspec_env => { 'RAILS_ENV' => 'test' }, :foreman => true do
  watch('config/routes.rb')
end

但是最近,当我添加新路线时,我刚刚开始收到以下错误:

Loading Spork.prefork block...
Rack::File headers parameter replaces cache_control after Rack 1.5.
Address already in use - bind(2) (Errno::EADDRINUSE)
/Users/cyrus/.rvm/rubies/ruby-1.9.3-p125/lib/ruby/1.9.1/drb/drb.rb:861:in `initialize'
/Users/cyrus/.rvm/rubies/ruby-1.9.3-p125/lib/ruby/1.9.1/drb/drb.rb:861:in `open'
/Users/cyrus/.rvm/rubies/ruby-1.9.3-p125/lib/ruby/1.9.1/drb/drb.rb:861:in `open_server'
/Users/cyrus/.rvm/rubies/ruby-1.9.3-p125/lib/ruby/1.9.1/drb/drb.rb:759:in `block in open_server'
/Users/cyrus/.rvm/rubies/ruby-1.9.3-p125/lib/ruby/1.9.1/drb/drb.rb:757:in `each'
/Users/cyrus/.rvm/rubies/ruby-1.9.3-p125/lib/ruby/1.9.1/drb/drb.rb:757:in `open_server'
/Users/cyrus/.rvm/rubies/ruby-1.9.3-p125/lib/ruby/1.9.1/drb/drb.rb:1342:in `initialize'
/Users/cyrus/.rvm/rubies/ruby-1.9.3-p125/lib/ruby/1.9.1/drb/drb.rb:1624:in `new'
/Users/cyrus/.rvm/rubies/ruby-1.9.3-p125/lib/ruby/1.9.1/drb/drb.rb:1624:in `start_service'
/Users/cyrus/.rvm/gems/ruby-1.9.3-p125@h/gems/spork-0.9.2/lib/spork/server.rb:29:in `listen'
/Users/cyrus/.rvm/gems/ruby-1.9.3-p125@h/gems/spork-0.9.2/lib/spork/server.rb:20:in `run'
/Users/cyrus/.rvm/gems/ruby-1.9.3-p125@h/gems/spork-0.9.2/lib/spork/runner.rb:75:in `run'
/Users/cyrus/.rvm/gems/ruby-1.9.3-p125@h/gems/spork-0.9.2/lib/spork/runner.rb:10:in `run'
/Users/cyrus/.rvm/gems/ruby-1.9.3-p125@h/gems/spork-0.9.2/bin/spork:10:in `<top (required)>'
/Users/cyrus/.rvm/gems/ruby-1.9.3-p125@h/bin/spork:23:in `load'
/Users/cyrus/.rvm/gems/ruby-1.9.3-p125@h/bin/spork:23:in `<main>'

通常当 spork 启动时,我会得到以下信息:

Loading Spork.prefork block...
Rack::File headers parameter replaces cache_control after Rack 1.5.
Spork is ready and listening on 8989!

如何避免此错误?

4

3 回答 3

2

我来到这里遇到与OP相同的问题。

在进入“错误是错误”帖子的兔子洞并检查发生故障的代码行之后,我沮丧地重新启动。执行此操作后,我意识到端口上的锁定可能来自于我已注销上一个桌面会话这一事实,并且 Spork DRb 服务器在关闭时挂起 RubyMine,所以也许这就是端口打开的原因。

果然,我现在可以启动 Spork 服务器了。

我添加了这个,以便其他面临这个问题的人可以考虑它是否符合他们的情况。

于 2013-03-08T22:53:30.350 回答
0

通过删除:foreman => trueinGuardfile我能够摆脱这个问题。现在我没有.env在我的测试中有意义地使用我的文件中的值,所以应该没问题,但我在 Github 上提交了一个问题。

于 2013-01-12T01:53:21.753 回答
0

看起来这个错误是一个错误:https ://github.com/rails/rails/pull/8812

于 2013-01-14T17:04:52.970 回答