1

这是我在 github 上创建的问题的复制+粘贴,但我也在这里问,以防有人知道如何解决它


使用 spork 0.9.0.rc9,我注意到显示规范运行多长时间的计时器不会在运行之间自行重置,而是输出自 spork 服务器启动以来累积的总时间。

重现步骤:

  1. 使用命令 spork 从控制台启动 spork
  2. 在另一个窗口中运行 rspec 。--drb
  3. 观察规范需要 X 秒才能运行,并且控制台输出验证了这一点
  4. 等待 60 秒,修改控制器规格,然后重复步骤 2
  5. 观察规范需要大约 Y 秒才能运行,但控制台输出声称它们需要 (X + Y + 60) 秒。
  6. 等待 10 分钟,重复步骤 2
  7. 观察规范在 Z 秒内运行,但控制台输出将数字置于 (X + Y + Z + 600) 秒

我的 spec_helper 只是 rspec-rails 为您生成的标准助手,我已将所有内容放入 spork prefork 块中,如下所示:

require 'rubygems'
require 'spork'

Spork.prefork do
  ENV["RAILS_ENV"] ||= 'test'
  require File.expand_path("../../config/environment", __FILE__)
  require 'rspec/rails'
  require 'rspec/autorun'

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

  RSpec.configure do |config|  
    config.fixture_path = "#{::Rails.root}/spec/fixtures"
    config.use_transactional_fixtures = true
    config.infer_base_class_for_anonymous_controllers = false
  end
end

我做错了吗?还是spork borked?

4

1 回答 1

4

对此有一个临时修复,这是一个已知的 rspec 问题。

临时修复可能不适用于 rspec 的未来版本,如下所示:

Spork.each_run do
  # you are advised that this may break in future versions of rspec
  $rspec_start_time = Time.now  
end

更新: 在guard-rspec here和 rspec-core here中报告了它。

于 2011-10-18T09:09:38.393 回答