这是我在 github 上创建的问题的复制+粘贴,但我也在这里问,以防有人知道如何解决它
使用 spork 0.9.0.rc9,我注意到显示规范运行多长时间的计时器不会在运行之间自行重置,而是输出自 spork 服务器启动以来累积的总时间。
重现步骤:
- 使用命令 spork 从控制台启动 spork
- 在另一个窗口中运行 rspec 。--drb
- 观察规范需要 X 秒才能运行,并且控制台输出验证了这一点
- 等待 60 秒,修改控制器规格,然后重复步骤 2
- 观察规范需要大约 Y 秒才能运行,但控制台输出声称它们需要 (X + Y + 60) 秒。
- 等待 10 分钟,重复步骤 2
- 观察规范在 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?