Merge branch 'main' into glitch-soc/merge-upstream
This commit is contained in:
@ -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
|
||||
|
@ -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
|
||||
|
Reference in New Issue
Block a user