RSpec加载速度极慢

时间:2014-07-15 17:51:25

标签: ruby-on-rails rspec

我正在从Rails 2.3升级Rails 3.2,并随之转到RSpec等新版本的宝石。

值得注意的是我的应用程序非常庞大:

$ rake stats
+----------------------+-------+-------+---------+---------+-----+-------+
| Name                 | Lines |   LOC | Classes | Methods | M/C | LOC/M |
+----------------------+-------+-------+---------+---------+-----+-------+
| Total                | 132568 | 96987 |    1108 |    7078 |   6 |    11 |
+----------------------+-------+-------+---------+---------+-----+-------+
  Code LOC: 55656     Test LOC: 41331     Code to Test Ratio: 1:0.7

我每天都在使用zeus,它在大约20秒内启动了测试环境,并且运行构建需要大约40分钟。

但是如果我跑

$ rspec

开始时需要4分53秒,然后从那里爬行。

我的规范助手并没有做任何疯狂的事情。我唯一真正删除的是rspec / autorun,这是让zeus不再执行所有操作所必需的。

# spec_helper.rb
ENV["Rails.env"] ||= 'test'
require File.expand_path("../../config/environment", __FILE__)
require 'rspec/rails'
require 'rspec/given'
require 'database_cleaner'
require 'capybara/rspec/matchers'
require 'debugger'

Dir[Rails.root.join("spec/support/**/*.rb")].each { |f| require f }

include FactoryGirl::Syntax::Methods

RSpec.configure do |config|
  config.treat_symbols_as_metadata_keys_with_true_values = true
  config.before(:suite) do
    DatabaseCleaner.strategy = :transaction
  end

  config.before(:each) do
    DatabaseCleaner.start
  end

  config.after(:each) do
    DatabaseCleaner.clean
  end

  config.fixture_path = "#{::Rails.root}/spec/fixtures"
  config.global_fixtures = :users, :roles
  config.use_transactional_fixtures = false
  config.infer_base_class_for_anonymous_controllers = false
  config.order = "random"

  def (ActionDispatch::Integration::Session).fixture_path
    RSpec.configuration.fixture_path
  end
end

编辑:为了记录,rake规范工作得很好。

1 个答案:

答案 0 :(得分:1)

密钥是ENV["Rails.env"],它不是一个正确形成的环境变量,它让一切变得疯狂。搜索和替换出错了。