Extend spec coverage for `Poll` model (#32500)

This commit is contained in:
Matt Jankowski 2024-10-15 08:48:10 -04:00 committed by Claire
parent 49b3d5692e
commit 0c59ef44b1
1 changed files with 19 additions and 7 deletions

View File

@ -3,7 +3,7 @@
require 'rails_helper' require 'rails_helper'
RSpec.describe Poll do RSpec.describe Poll do
describe 'scopes' do describe 'Scopes' do
let(:status) { Fabricate(:status) } let(:status) { Fabricate(:status) }
let(:attached_poll) { Fabricate(:poll, status: status) } let(:attached_poll) { Fabricate(:poll, status: status) }
let(:not_attached_poll) do let(:not_attached_poll) do
@ -13,7 +13,7 @@ RSpec.describe Poll do
end end
end end
describe 'attached' do describe '.attached' do
it 'finds the correct records' do it 'finds the correct records' do
results = described_class.attached results = described_class.attached
@ -21,7 +21,7 @@ RSpec.describe Poll do
end end
end end
describe 'unattached' do describe '.unattached' do
it 'finds the correct records' do it 'finds the correct records' do
results = described_class.unattached results = described_class.unattached
@ -30,11 +30,23 @@ RSpec.describe Poll do
end end
end end
describe 'validations' do describe '#reset_votes!' do
context 'when not valid' do let(:poll) { Fabricate :poll, cached_tallies: [2, 3], votes_count: 5, voters_count: 5 }
subject { Fabricate.build(:poll) } let!(:vote) { Fabricate :poll_vote, poll: }
it { is_expected.to validate_presence_of(:expires_at) } it 'resets vote data and deletes votes' do
expect { poll.reset_votes! }
.to change(poll, :cached_tallies).to([0, 0])
.and change(poll, :votes_count).to(0)
.and(change(poll, :voters_count).to(0))
expect { vote.reload }
.to raise_error(ActiveRecord::RecordNotFound)
end end
end end
describe 'Validations' do
subject { Fabricate.build(:poll) }
it { is_expected.to validate_presence_of(:expires_at) }
end
end end