2014-03-19 47 views
0

有没有人遇到类似的问题?数据库清理程序不应该删除数据

我有一个控制器,这将触发邮件交付:

def create 
    create! do |success, failure| 
     success.js do 
     CandidateMailer.donation_notification(current_candidate).deliver 
     end 
    end 
    end 

而我得到的邮件:

def donation_notification(candidate) 
    puts Candidate.count # note: during test - count of candidates is 0 
    @candidate = candidate 
    email_with_name = "#{@candidate.profile.name} <#{@candidate.email}>" 
    mail(to: email_with_name, subject: 'New Donation Received!') 
    end 

我不明白为什么数据库清理删除所有数据前测试是实际完成。

这是一个JS测试(使用Webkit),如果这很重要的话。

这里是我的配置:

RSpec.configure do |config| 

    config.before(:suite) do 
    DatabaseCleaner.clean_with :truncation 
    end 

    config.before(:each) do 
    if Capybara.current_driver == :rack_test 
     DatabaseCleaner.strategy = :transaction 
    else 
     DatabaseCleaner.strategy = [:truncation, { pre_count: true }] 
    end 

    DatabaseCleaner.start 
    end 

    config.after(:each) do 
    DatabaseCleaner.clean 
    end 
end 
+0

如果您可以分享rspec示例,那将会很有帮助。 –

回答

0

如果我从code正确认识,既cleanclean_with实际上委托给strategy.clean,这意味着他们都积极干净。

当你调用

config.before(:suite) do 
    DatabaseCleaner.clean_with :truncation 
    end 

它清理你的数据库的测试开始之前。

在测试情况下,如果您将测试数据放在套件的开头(或每次测试之前),这可能是正确的。