debian-mirror-gitlab/spec/lib/gitlab/sidekiq_status_spec.rb

141 lines
3.6 KiB
Ruby
Raw Normal View History

2019-12-04 20:38:33 +05:30
# frozen_string_literal: true
2017-08-17 22:00:37 +05:30
require 'spec_helper'
2021-09-30 23:02:18 +05:30
RSpec.describe Gitlab::SidekiqStatus, :clean_gitlab_redis_queues, :clean_gitlab_redis_shared_state do
describe '.set' do
2017-08-17 22:00:37 +05:30
it 'stores the job ID' do
described_class.set('123')
key = described_class.key_for('123')
Sidekiq.redis do |redis|
expect(redis.exists(key)).to eq(true)
expect(redis.ttl(key) > 0).to eq(true)
2022-03-02 08:16:31 +05:30
expect(redis.get(key)).to eq('1')
2022-01-26 12:08:38 +05:30
end
end
it 'allows overriding the expiration time' do
described_class.set('123', described_class::DEFAULT_EXPIRATION * 2)
key = described_class.key_for('123')
Sidekiq.redis do |redis|
expect(redis.exists(key)).to eq(true)
expect(redis.ttl(key) > described_class::DEFAULT_EXPIRATION).to eq(true)
2022-03-02 08:16:31 +05:30
expect(redis.get(key)).to eq('1')
2022-01-26 12:08:38 +05:30
end
end
2022-03-02 08:16:31 +05:30
it 'does not store anything with a nil expiry' do
described_class.set('123', nil)
2022-01-26 12:08:38 +05:30
key = described_class.key_for('123')
Sidekiq.redis do |redis|
2022-03-02 08:16:31 +05:30
expect(redis.exists(key)).to eq(false)
2017-08-17 22:00:37 +05:30
end
end
end
2021-09-30 23:02:18 +05:30
describe '.unset' do
2017-08-17 22:00:37 +05:30
it 'removes the job ID' do
described_class.set('123')
described_class.unset('123')
key = described_class.key_for('123')
Sidekiq.redis do |redis|
expect(redis.exists(key)).to eq(false)
end
end
end
2021-09-30 23:02:18 +05:30
describe '.all_completed?' do
2017-08-17 22:00:37 +05:30
it 'returns true if all jobs have been completed' do
expect(described_class.all_completed?(%w(123))).to eq(true)
end
it 'returns false if a job has not yet been completed' do
described_class.set('123')
expect(described_class.all_completed?(%w(123 456))).to eq(false)
end
end
2021-09-30 23:02:18 +05:30
describe '.running?' do
2018-03-17 18:26:18 +05:30
it 'returns true if job is running' do
described_class.set('123')
expect(described_class.running?('123')).to be(true)
end
it 'returns false if job is not found' do
expect(described_class.running?('123')).to be(false)
end
end
2021-09-30 23:02:18 +05:30
describe '.num_running' do
2017-08-17 22:00:37 +05:30
it 'returns 0 if all jobs have been completed' do
expect(described_class.num_running(%w(123))).to eq(0)
end
it 'returns 2 if two jobs are still running' do
described_class.set('123')
described_class.set('456')
expect(described_class.num_running(%w(123 456 789))).to eq(2)
end
end
2021-09-30 23:02:18 +05:30
describe '.num_completed' do
2017-08-17 22:00:37 +05:30
it 'returns 1 if all jobs have been completed' do
expect(described_class.num_completed(%w(123))).to eq(1)
end
it 'returns 1 if a job has not yet been completed' do
described_class.set('123')
described_class.set('456')
expect(described_class.num_completed(%w(123 456 789))).to eq(1)
end
end
describe '.key_for' do
it 'returns the key for a job ID' do
key = described_class.key_for('123')
expect(key).to be_an_instance_of(String)
expect(key).to include('123')
end
end
2022-01-26 12:08:38 +05:30
describe '.completed_jids' do
2017-08-17 22:00:37 +05:30
it 'returns the completed job' do
expect(described_class.completed_jids(%w(123))).to eq(['123'])
end
it 'returns only the jobs completed' do
described_class.set('123')
described_class.set('456')
expect(described_class.completed_jids(%w(123 456 789))).to eq(['789'])
end
end
2022-01-26 12:08:38 +05:30
describe '.job_status' do
it 'returns an array of boolean values' do
described_class.set('123')
described_class.set('456')
described_class.unset('123')
expect(described_class.job_status(%w(123 456 789))).to eq([false, true, false])
end
it 'handles an empty array' do
expect(described_class.job_status([])).to eq([])
end
end
2017-08-17 22:00:37 +05:30
end