| 
									
										
										
										
											2023-03-04 09:56:09 -06:00
										 |  |  | # frozen_string_literal: true | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | require 'rails_helper' | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | describe PollExpirationNotifyWorker do | 
					
						
							|  |  |  |   let(:worker) { described_class.new } | 
					
						
							| 
									
										
										
										
											2023-03-29 03:52:40 -05:00
										 |  |  |   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) } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-01-10 05:06:58 -06:00
										 |  |  |   describe '#perform' do | 
					
						
							| 
									
										
										
										
											2023-03-04 09:56:09 -06:00
										 |  |  |     it 'runs without error for missing record' do | 
					
						
							|  |  |  |       expect { worker.perform(nil) }.to_not raise_error | 
					
						
							|  |  |  |     end | 
					
						
							| 
									
										
										
										
											2023-03-29 03:52:40 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     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 | 
					
						
							| 
									
										
										
										
											2023-03-04 09:56:09 -06:00
										 |  |  |   end | 
					
						
							|  |  |  | end |