为什么我的rspec测试在Ruby 1.9.2中的运行速度比1.8.7慢?

kre*_*eek 6 ruby unit-testing rspec sinatra spork

我正在使用spork来测试Sinatra应用程序,使用Ruby 1.9.2,测试运行时间约为3.5秒,但在Ruby 1.8.7中,它们平均为1.2秒.我确实尝试过Ruby 1.9.3甚至是JRuby,但他们使用的宝石有一些错误.有没有办法将Ruby 1.9.2的rspec性能提升到1.8.7的水平?

我的Gemfile:

source :rubygems
gem 'sinatra', '1.3.1'
gem 'thin', '1.3.1'
gem 'haml', '3.1.4'
gem 'datamapper', '1.2.0'
gem 'dm-postgres-adapter', '1.2.0'
gem 'carrierwave', '0.5.8'
gem 'carrierwave-datamapper', '0.2.0'

group :test do
  gem "dm-sqlite-adapter"
  gem "spork"
  gem "rspec"
  gem "rack-test"
end
Run Code Online (Sandbox Code Playgroud)

spec_helper.rb:

require 'rubygems'
require 'spork'
require 'sinatra'
require 'rack/test'
require 'rspec'

require File.join(File.dirname(__FILE__), '..', 'app.rb')
require File.join(File.dirname(__FILE__), '..', 'model/model.rb')

Spork.prefork do
  set :environment, :test
  set :files, "test_files"
end

Spork.each_run do
  RSpec.configure do |config|
    config.before(:each) { DataMapper.auto_migrate! }
    config.after(:all) do
      FileUtils.rm_rf(Dir["#{settings.root}/public/test_files"])
    end 
  end
end
Run Code Online (Sandbox Code Playgroud)

谢谢!

Jam*_*ney 2

ruby 1.9.2 在启动过程中需要文件的方式存在问题: http://rhnh.net/2011/05/28/speeding-up-rails-startup-time

1.9.3 对此 IIRC 进行了部分修复。