123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- require 'rails_helper'
- RSpec.describe BackgroundServices::Service::ProcessScheduledJobs do
- let(:instance) { described_class.new(manager: nil) }
- let(:scheduler_1) { create(:scheduler, active: true, prio: 5) }
- let(:scheduler_2) { create(:scheduler, active: true, prio: 1) }
- let(:scheduler_3) { create(:scheduler, active: false, prio: 3) }
- before do
- stub_const("#{described_class}::SLEEP_AFTER_JOB_START", 0)
- stub_const("#{described_class}::SLEEP_AFTER_LOOP", 0)
- Scheduler.destroy_all
- end
- describe '#run' do
- before do
- allow(instance).to receive(:run_jobs)
- end
- it 'keeps running jobs', ensure_threads_exited: true do
- ensure_block_keeps_running { instance.run }
- expect(instance).to have_received(:run_jobs).at_least(2)
- end
- context 'when shutdown is requested' do
- before do
- allow(BackgroundServices).to receive(:shutdown_requested).and_return(true)
- end
- it 'does not start jobs' do
- instance.run
- expect(instance).not_to have_received(:run_jobs)
- end
- end
- end
- describe '#run_jobs' do
- let(:log) { [] }
- before do
- allow_any_instance_of(described_class::Manager).to receive(:run) do
- log << :run_called
- end
- scheduler_1
- end
- it 'runs manager for each active job' do
- instance.send(:run_jobs)
- expect(log).to be_one
- end
- context 'when shutdown is requested' do
- before do
- allow(BackgroundServices).to receive(:shutdown_requested).and_return(true)
- end
- it 'does not run managers' do
- instance.send(:run_jobs)
- expect(log).to be_empty
- end
- end
- end
- describe '#scope' do
- it 'returns active scheduled jobs by priority' do
- scheduler_1 && scheduler_2 && scheduler_3
- expect(instance.send(:scope)).to eq [scheduler_2, scheduler_1]
- end
- end
- end
|