Merge branch 'main' into glitch-soc/merge-upstream

This commit is contained in:
Claire
2023-03-02 17:32:38 +01:00
97 changed files with 1412 additions and 523 deletions

View File

@ -18,4 +18,30 @@ describe AccountFilter do
expect { filter.results }.to raise_error(/wrong/)
end
end
describe 'with origin and by_domain interacting' do
let!(:local_account) { Fabricate(:account, domain: nil) }
let!(:remote_account_one) { Fabricate(:account, domain: 'example.org') }
let(:remote_account_two) { Fabricate(:account, domain: 'other.domain') }
it 'works with domain first and origin remote' do
filter = described_class.new(by_domain: 'example.org', origin: 'remote')
expect(filter.results).to match_array [remote_account_one]
end
it 'works with domain last and origin remote' do
filter = described_class.new(origin: 'remote', by_domain: 'example.org')
expect(filter.results).to match_array [remote_account_one]
end
it 'works with domain first and origin local' do
filter = described_class.new(by_domain: 'example.org', origin: 'local')
expect(filter.results).to match_array [local_account]
end
it 'works with domain last and origin local' do
filter = described_class.new(origin: 'local', by_domain: 'example.org')
expect(filter.results).to match_array [remote_account_one]
end
end
end

View File

@ -10,4 +10,53 @@ RSpec.describe PollVote, type: :model do
expect(poll_vote.object_type).to eq :vote
end
end
describe 'validations' do
context 'with a vote on an expired poll' do
it 'marks the vote invalid' do
poll = Fabricate.build(:poll, expires_at: 30.days.ago)
vote = Fabricate.build(:poll_vote, poll: poll)
expect(vote).to_not be_valid
end
end
context 'with invalid choices' do
it 'marks vote invalid with negative choice' do
poll = Fabricate.build(:poll)
vote = Fabricate.build(:poll_vote, poll: poll, choice: -100)
expect(vote).to_not be_valid
end
it 'marks vote invalid with choice in excess of options' do
poll = Fabricate.build(:poll, options: %w(a b c))
vote = Fabricate.build(:poll_vote, poll: poll, choice: 10)
expect(vote).to_not be_valid
end
end
context 'with a poll where multiple is true' do
it 'does not allow a second vote on same choice from same account' do
poll = Fabricate(:poll, multiple: true, options: %w(a b c))
first_vote = Fabricate(:poll_vote, poll: poll, choice: 1)
expect(first_vote).to be_valid
second_vote = Fabricate.build(:poll_vote, account: first_vote.account, poll: poll, choice: 1)
expect(second_vote).to_not be_valid
end
end
context 'with a poll where multiple is false' do
it 'does not allow a second vote from same account' do
poll = Fabricate(:poll, multiple: false, options: %w(a b c))
first_vote = Fabricate(:poll_vote, poll: poll)
expect(first_vote).to be_valid
second_vote = Fabricate.build(:poll_vote, account: first_vote.account, poll: poll)
expect(second_vote).to_not be_valid
end
end
end
end