在运行rspec的过程中需要产生测试数据,测试数据没有即使删除则会造成测试数据的膨胀,更重要的是在controller的测试中将会严重影响测试结果和测试效率。而database cleaner则为我们提供了及时清理测试数据的方法。
要使用database cleaner首先需要进行gem安装,
运行:sudo gem install database_cleaner,并在Gemfile中增加gem 'database_cleaner',之后执行bundle install。
这时你的项目中已经安装了database_cleaner,但仅仅安装还不能直接拿来直接使用,需要在spec/spec_helper.rb中进行相应的配置。
本人使用的postgresql,在使用过程中一个好的清理策略可以将rspec的执行效率至少提高
30-40%,当然这要根据不同功能的需要,下面是一个简单的配置。
RSpec.configure do |config|
config.before(:suite) do
DatabaseCleaner.clean_with(:truncation)
end
config.before(:each) do
DatabaseCleaner.strategy = :transaction
end
config.before(:each, :js => true) do
DatabaseCleaner.strategy = :truncation
end
config.before(:each) do
DatabaseCleaner.start
end
config.after(:each) do
DatabaseCleaner.clean
end
end
当然配置的前提是,你的spec_helper文件已经进行了前期的配置。
修改:config.use_transactional_fixtures = true
为:
config.use_transactional_fixtures = false
这样可以关闭数据库事务中所隐藏的测试数据。 同时,请确保你的配置文件是正确的,如果环境配置存在问题,你将始终面对着各种各样的错误而摸不着头脑。 以下是环境的简单配置,可以作为参考:ENV["RAILS_ENV"] ||= 'test' require File.expand_path("../../config/environment", __FILE__) require 'rspec/rails' require 'database_cleaner'