FIX: Don't log a claimed topic database error during tests

We now test the uniqueness validation, but also rescue a DB
exception in case the controller fails this check.
This commit is contained in:
Robin Ward
2020-01-09 12:32:05 -05:00
parent d043a4c6fe
commit dcbe527a82
4 changed files with 21 additions and 6 deletions

View File

@ -4,11 +4,14 @@ require 'rails_helper'
RSpec.describe ReviewableClaimedTopic, type: :model do
it "ensures uniqueness" do
claimed = Fabricate(:reviewable_claimed_topic)
expect(-> {
ReviewableClaimedTopic.create!(topic_id: claimed.topic_id, user_id: Fabricate(:user).id)
}).to raise_error(ActiveRecord::RecordNotUnique)
it "respects the uniqueness constraint" do
topic = Fabricate(:topic)
ct = ReviewableClaimedTopic.new(topic_id: topic.id, user_id: Fabricate(:user).id)
expect(ct.save).to eq(true)
ct = ReviewableClaimedTopic.new(topic_id: topic.id, user_id: Fabricate(:user).id)
expect(ct.save).to eq(false)
end
end