我正在尝试使用 rspec 测试我的 rake 任务,它运行良好,但问题是之后没有删除记录。
我已将 config.use_transactional_fixtures = true
放入配置文件中,没有任何影响。在其他测试中,它运行良好。
这是我的代码:
require 'rspec'
require 'spec_helper'
require 'rake'
describe 'my_app rake tasks' do
describe 'rake_task_1' do
before { MyApp::Application.load_tasks }
it 'should test it!' do
10.times { create(:record) }
Rake::Task["rake_task_1"].invoke
Record.count.should == 10
end
end
end
在我的 rake 任务中,我正在使用 ActiveRecord::Base.connection.execute
执行查询。
我确定它与 RSepc 中的 SQL 转换有关....
有什么想法吗?
最佳答案
您是否尝试过使用 database_cleaner
gem ?
您可以查看 great article by Avdi Grimm关于如何配置它。
config.use_transactional_fixtures = false
在文件 spec/support/database_cleaner.rb
中:
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
关于ruby-on-rails - 使用 RSpec 测试 rake 任务后清除数据库,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22590620/