当我添加此测试并运行整套测试时,另一个测试失败。每次都是不同的,但错误始终是一样的。
我正在使用Rails,使用Devise和Paranoia(这是我正在测试的,用于软删除)。
这是错误:
SQLite3::ConstraintException: UNIQUE constraint failed: users.email: INSERT INTO "users" ("last_sign_in_at", "current_sign_in_at", "last_sign_in_ip", "current_sign_in_ip", "sign_in_count") VALUES (?, ?, ?, ?, ?)
这是使其他测试失败的测试。
require "rails_helper"
feature "User soft deletes project" do
scenario "successfully" do
user = create(:user)
login_as(user, scope: :user)
project = create(:project, creator: user)
visit edit_user_project_path(user, project)
expect {
click_on "Delete Project"
}.to change(Project, :count).by(-1)
expect(page).to have_content("Project was successfully destroyed")
expect(Project.unscoped.count).to eq(1)
end
end
答案 0 :(得分:2)
好像你没有在每个测试套件之间清除数据库。例如,您为第一个测试套件创建了一个用户。在您的下一个测试套件中,您将使用相同的电子邮件再次创建一个用户,该电子邮件应该是唯一的,并且您会收到该错误。将database_cleaner
gem添加到Gemfile
,运行bundle install
并将其添加到spec_helper.rb
config.before(:suite) do
DatabaseCleaner.strategy = :transaction
DatabaseCleaner.clean_with(:truncation)
end