2022-07-23 23:45:48 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
RSpec.describe Gitlab::Redis::DuplicateJobs do
|
|
|
|
# Note: this is a pseudo-store in front of `SharedState`, meant only as a tool
|
|
|
|
# to move away from `Sidekiq.redis` for duplicate job data. Thus, we use the
|
|
|
|
# same store configuration as the former.
|
|
|
|
let(:instance_specific_config_file) { "config/redis.shared_state.yml" }
|
|
|
|
let(:environment_config_file_name) { "GITLAB_REDIS_SHARED_STATE_CONFIG_FILE" }
|
|
|
|
|
|
|
|
include_examples "redis_shared_examples"
|
|
|
|
|
|
|
|
describe '#pool' do
|
|
|
|
subject { described_class.pool }
|
|
|
|
|
|
|
|
around do |example|
|
|
|
|
clear_pool
|
|
|
|
example.run
|
|
|
|
ensure
|
|
|
|
clear_pool
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'store connection settings' do
|
|
|
|
let(:config_new_format_host) { "spec/fixtures/config/redis_new_format_host.yml" }
|
|
|
|
let(:config_new_format_socket) { "spec/fixtures/config/redis_new_format_socket.yml" }
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(Gitlab::Redis::SharedState).to receive(:config_file_name).and_return(config_new_format_host)
|
|
|
|
allow(Gitlab::Redis::Queues).to receive(:config_file_name).and_return(config_new_format_socket)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'instantiates an instance of MultiStore' do
|
|
|
|
subject.with do |redis_instance|
|
|
|
|
expect(redis_instance).to be_instance_of(::Gitlab::Redis::MultiStore)
|
|
|
|
|
|
|
|
expect(redis_instance.primary_store.connection[:id]).to eq("redis://test-host:6379/99")
|
|
|
|
expect(redis_instance.primary_store.connection[:namespace]).to be_nil
|
2022-10-11 01:57:18 +05:30
|
|
|
expect(redis_instance.secondary_store.connection[:id]).to eq("unix:///path/to/redis.sock/0")
|
2022-07-23 23:45:48 +05:30
|
|
|
expect(redis_instance.secondary_store.connection[:namespace]).to eq("resque:gitlab")
|
|
|
|
|
|
|
|
expect(redis_instance.instance_name).to eq('DuplicateJobs')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# Make sure they current namespace is respected for the secondary store but omitted from the primary
|
|
|
|
context 'key namespaces' do
|
|
|
|
let(:key) { 'key' }
|
|
|
|
let(:value) { '123' }
|
|
|
|
|
|
|
|
it 'writes keys to SharedState with no prefix, and to Queues with the "resque:gitlab:" prefix' do
|
|
|
|
subject.with do |redis_instance|
|
|
|
|
redis_instance.set(key, value)
|
|
|
|
end
|
|
|
|
|
|
|
|
Gitlab::Redis::SharedState.with do |redis_instance|
|
|
|
|
expect(redis_instance.get(key)).to eq(value)
|
|
|
|
end
|
|
|
|
|
|
|
|
Gitlab::Redis::Queues.with do |redis_instance|
|
|
|
|
expect(redis_instance.get("resque:gitlab:#{key}")).to eq(value)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'multi store feature flags', :use_primary_and_secondary_stores_for_duplicate_jobs,
|
|
|
|
:use_primary_store_as_default_for_duplicate_jobs
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#raw_config_hash' do
|
|
|
|
it 'has a legacy default URL' do
|
|
|
|
expect(subject).to receive(:fetch_config) { false }
|
|
|
|
|
|
|
|
expect(subject.send(:raw_config_hash)).to eq(url: 'redis://localhost:6382')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
describe '#store_name' do
|
|
|
|
it 'returns the name of the SharedState store' do
|
|
|
|
expect(described_class.store_name).to eq('SharedState')
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|