【发布时间】:2013-12-19 22:39:28
【问题描述】:
我在我的 Rails 应用程序中运行警卫,测试套件(分钟)最近停止正常工作。
如果我幸运的话,它会运行所有测试一次,也许两次。在那之后,即使是一个很小的测试文件被更改也需要很长时间才能响应,以至于使用 gem 变得徒劳。
在测试运行时关注top 时,我可以看到有一个 ruby 进程不断地占用超过 100% 的 CPU。即使运行了所有测试并且我没有对文件进行任何更改。
ruby 进程是:
/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-p247
这是我的设置:
# 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
宝石版本:
- minitest (4.7.5)
- minitest-capybara (0.5.0)
- minitest-focus (1.1.0)
- minitest-元数据 (0.4.0)
- minitest-rails (0.9.2)
- minitest-rails-capybara (0.10.0)
- mobvious-rails (0.1.2)
- 摩卡(0.14.0)
- 守卫 (2.2.4)
- 保护-minitest (2.1.2)
- rb-fsevent (0.9.3)
【问题讨论】:
标签: ruby-on-rails ruby guard minitest