123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- # frozen_string_literal: true
- require 'rails_helper'
- describe PollExpirationNotifyWorker do
- let(:worker) { described_class.new }
- let(:account) { Fabricate(:account, domain: remote? ? 'example.com' : nil) }
- let(:status) { Fabricate(:status, account: account) }
- let(:poll) { Fabricate(:poll, status: status, account: account) }
- let(:remote?) { false }
- let(:poll_vote) { Fabricate(:poll_vote, poll: poll) }
- describe '#perform', :sidekiq_fake do
- it 'runs without error for missing record' do
- expect { worker.perform(nil) }.to_not raise_error
- end
- context 'when poll is not expired' do
- it 'requeues job' do
- worker.perform(poll.id)
- expect(described_class.sidekiq_options_hash['lock']).to be :until_executing
- expect(described_class).to have_enqueued_sidekiq_job(poll.id).at(poll.expires_at + 5.minutes)
- end
- end
- context 'when poll is expired' do
- before do
- poll_vote
- travel_to poll.expires_at + 5.minutes
- worker.perform(poll.id)
- end
- context 'when poll is local' do
- it 'notifies voters' do
- expect(ActivityPub::DistributePollUpdateWorker).to have_enqueued_sidekiq_job(poll.status.id)
- end
- it 'notifies owner' do
- expect(LocalNotificationWorker).to have_enqueued_sidekiq_job(poll.account.id, poll.id, 'Poll', 'poll')
- end
- it 'notifies local voters' do
- expect(LocalNotificationWorker).to have_enqueued_sidekiq_job(poll_vote.account.id, poll.id, 'Poll', 'poll')
- end
- end
- context 'when poll is remote' do
- let(:remote?) { true }
- it 'does not notify remote voters' do
- expect(ActivityPub::DistributePollUpdateWorker).to_not have_enqueued_sidekiq_job(poll.status.id)
- end
- it 'does not notify owner' do
- expect(LocalNotificationWorker).to_not have_enqueued_sidekiq_job(poll.account.id, poll.id, 'Poll', 'poll')
- end
- it 'notifies local voters' do
- expect(LocalNotificationWorker).to have_enqueued_sidekiq_job(poll_vote.account.id, poll.id, 'Poll', 'poll')
- end
- end
- end
- end
- end
|