81 lines
2.1 KiB
Ruby
81 lines
2.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe LimitedCapacity::JobTracker, :clean_gitlab_redis_queues do
|
|
let(:job_tracker) do
|
|
described_class.new('namespace')
|
|
end
|
|
|
|
let(:max_jids) { 10 }
|
|
|
|
describe '#register' do
|
|
it 'adds jid to the set' do
|
|
expect(job_tracker.register('a-job-id', max_jids)). to be true
|
|
expect(job_tracker.running_jids).to contain_exactly('a-job-id')
|
|
end
|
|
|
|
it 'returns false if the jid was not added' do
|
|
max_jids = 2
|
|
%w[jid1 jid2].each do |jid|
|
|
expect(job_tracker.register(jid, max_jids)).to be true
|
|
end
|
|
|
|
expect(job_tracker.register('jid3', max_jids)).to be false
|
|
expect(job_tracker.running_jids).to contain_exactly(*%w[jid1 jid2])
|
|
end
|
|
end
|
|
|
|
describe '#remove' do
|
|
before do
|
|
%w[a-job-id other-job-id].each do |jid|
|
|
job_tracker.register(jid, max_jids)
|
|
end
|
|
end
|
|
|
|
it 'removes jid from the set' do
|
|
job_tracker.remove('other-job-id')
|
|
|
|
expect(job_tracker.running_jids).to contain_exactly('a-job-id')
|
|
end
|
|
end
|
|
|
|
describe '#clean_up' do
|
|
before do
|
|
job_tracker.register('a-job-id', max_jids)
|
|
end
|
|
|
|
context 'with running jobs' do
|
|
before do
|
|
expect(Gitlab::SidekiqStatus).to receive(:completed_jids)
|
|
.with(%w[a-job-id])
|
|
.and_return([])
|
|
end
|
|
|
|
it 'does not remove the jid from the set' do
|
|
expect { job_tracker.clean_up }
|
|
.not_to change { job_tracker.running_jids.include?('a-job-id') }
|
|
end
|
|
|
|
it 'does only one Redis call to get the job ids' do
|
|
expect(job_tracker).to receive(:with_redis).once.and_call_original
|
|
|
|
job_tracker.clean_up
|
|
end
|
|
end
|
|
|
|
context 'with completed jobs' do
|
|
it 'removes the jid from the set' do
|
|
expect { job_tracker.clean_up }
|
|
.to change { job_tracker.running_jids.include?('a-job-id') }
|
|
end
|
|
|
|
it 'gets the job ids, removes them, and updates the counter with only two Redis calls' do
|
|
expect(job_tracker).to receive(:with_redis).twice.and_call_original
|
|
|
|
job_tracker.clean_up
|
|
end
|
|
end
|
|
end
|
|
end
|