首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Rails,Minitest和Guard -为什么rb-fsevent占用了超过100%的CPU?

Rails,Minitest和Guard -为什么rb-fsevent占用了超过100%的CPU?
EN

Stack Overflow用户
提问于 2013-12-03 18:09:35
回答 1查看 1.7K关注 0票数 7

我在Rails应用程序中运行保护程序,测试套件(minutest)最近停止正常工作。

如果我幸运的话,它会运行所有的测试一次,也许两次。在此之后,即使更改一个小测试文件也需要很长时间才能做出响应,以致于使用gem变得徒劳无功。

在测试运行时,我可以看到,在运行top时,有一个红宝石进程,它占用了CPU 的100%以上的。即使所有测试都运行了,我也没有对文件做任何更改。

红宝石工艺是:

代码语言:javascript
复制
/Users/Bodacious/.rvm/gems/ruby-2.0.0-p247@MyApp/gems/rb-fsevent-0.9.3/bin/fsevent_watch --latency 0.1 /Users/Bodaiou/Clients/MyApp

(进程31332)在所附的屏幕截图中。

Ruby 2.0.0-p 247

这是我的装置:

代码语言:javascript
复制
# Gemfile (with irrelevant gems removed)
gem 'rails', '4.0.0'
group :test do
  gem 'launchy'
  gem "mocha", require: false
  gem 'database_cleaner'
  gem 'selenium-webdriver'
  gem 'capybara-webkit' # for headless javascript tests
  gem 'timecop'
  gem "minitest-focus"
end

group :development, :test do
  gem "minitest-rails"
  gem "minitest-rails-capybara"
  gem 'zeus'
  gem 'guard'
  gem 'guard-minitest'
  gem 'factory_girl_rails'
end


# Guardfile
guard :minitest, all_on_start: false do
  # Rails 4
  watch(%r{^app/(.+)\.rb})                               { |m| "test/#{m[1]}_test.rb" }
  watch(%r{^app/controllers/application_controller\.rb}) { 'test/controllers' }
  watch(%r{^app/controllers/(.+)_controller\.rb})        { |m| "test/integration/#{m[1]}_test.rb" }
  watch(%r{^app/views/(.+)_mailer/.+})                   { |m| "test/mailers/#{m[1]}_mailer_test.rb" }
  watch(%r{^lib/(.+)\.rb})                               { |m| "test/lib/#{m[1]}_test.rb" }
  watch(%r{^test/.+_test\.rb})
  watch(%r{^test/test_helper\.rb})                       { 'test' }

  ignore(%r{^tmp/})

end

# test_helper
ENV["RAILS_ENV"] = "test"
require File.expand_path("../../config/environment", __FILE__)

require 'rails/test_help'
require 'minitest/autorun'
require 'minitest/pride'
require "minitest/rails/capybara"

require "mocha/setup"

# Sidekiq https://github.com/mperham/sidekiq/wiki/Testing
require 'sidekiq/testing'
Sidekiq::Testing.fake!

Dir[Rails.root.join('test', 'support', '*.rb')].each do |file|
  require file
end


class MiniTest::Spec
  include FactoryGirl::Syntax::Methods
  include AllTestHelper

end


class ActiveSupport::TestCase
  include FactoryGirl::Syntax::Methods
  include AllTestHelper
end

class Capybara::Rails::TestCase
  include Rails.application.routes.url_helpers 
  include Capybara::DSL
  include Capybara::Assertions
  include IntegrationTestHelper

  # Called before each Feature spec
  before :each do
  end

  # Called after each Feature spec
  after :each do
    Capybara.reset_sessions!
  end
end

Gem版本:

  • 最低者(4.7.5)
  • 最小型-水豚(0.5.0)
  • 最小对焦(1.1.0)
  • 最小元数据(0.4.0)
  • 最小-钢轨(0.9.2)
  • 最小型铁路-水豚(0.10.0)
  • 导轨(0.1.2)
  • 摩卡(0.14.0)
  • 警卫(2.2.4)
  • 警卫人数最少(2.1.2)
  • 经常预算(0.9.3)
EN

回答 1

Stack Overflow用户

发布于 2013-12-12 12:23:34

解决方案:

我通过在我的Guardfile中添加一个“忽略”语句来解决这个问题。对于我的rails 3项目,它看起来如下(./Guardfile):

代码语言:javascript
复制
ignore([%r{^bin/*}, %r{^config/*}, %r{^db/*}, %r{^lib/*}, %r{^log/*}, %r{^public/*}, %r{^tmp/*}])

guard 'rspec', cmd: 'spring rspec', all_after_pass: false, all_on_start: false, focus_on_failed: true do
  # Rails
  watch(%r{^spec/.+_spec\.rb$})
  ...
end

这似乎是警卫/rspec/rails的最佳实践。

守卫“忽略”信息:https://github.com/guard/guard/wiki/Guardfile-DSL---Configuring-Guard#ignore

我的问题

在我的mac os x 10.9机器上,我遇到了非常类似的情况,使用:

  • 春季(1.0.0)
  • 经常预算(0.9.3)
  • 咆哮(1.0.3)
  • rspec-核心(2.14.7)
  • rspec-预期(2.14.4)
  • rspec-模拟(2.14.4)
  • rspec (2.14.1)
  • 警卫-rspec (4.2.0)
  • 听(2.4.0)
  • rspec-rails (2.14.0)
  • rails (3.2.15)

在启动警卫运行我的rspec测试后,这个保护过程跳到100%负载在一个核心上,而“空转”,它保持了这样长的时间,使我有资格成为“永远”。:)

我试着逃跑

  • 强制轮询
  • 没有“观察”声明
  • 用弹簧
  • 无弹簧

没有变化。

我的同事在linux上工作,所以他使用rb-inotify而不是rb-fsevent。他空转时没有负担(就像你对mac os期望的那样.)。

正如上面所写的,我的解决方案是在我的Guardfile中添加一个“忽略”语句。

票数 19
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20358502

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档