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

时间:2011-12-07 22:05:39

标签: 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

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

谢谢!

2 个答案:

答案 0 :(得分:2)

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

1.9.3对IIRC有部分修复。

答案 1 :(得分:1)

不是根据rspec自己的测试:https://gist.github.com/939865。它应该更快。它可能会在你的堆栈中变慢。