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

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

57 lines
2.1 KiB
Ruby
Raw Normal View History

2022-07-23 23:45:48 +05:30
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Gitlab::Redis::SidekiqStatus do
# Note: this is a pseudo-store in front of `SharedState`, meant only as a tool
# to move away from `Sidekiq.redis` for sidekiq status data. Thus, we use the
# same store configuration as the former.
let(:instance_specific_config_file) { "config/redis.shared_state.yml" }
include_examples "redis_shared_examples"
describe '#pool' 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" }
2023-04-23 21:23:45 +05:30
let(:rails_root) { mktmpdir }
2022-07-23 23:45:48 +05:30
subject { described_class.pool }
before do
2023-04-23 21:23:45 +05:30
# Override rails root to avoid having our fixtures overwritten by `redis.yml` if it exists
allow(Gitlab::Redis::SharedState).to receive(:rails_root).and_return(rails_root)
allow(Gitlab::Redis::Queues).to receive(:rails_root).and_return(rails_root)
2022-07-23 23:45:48 +05:30
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
around do |example|
clear_pool
example.run
ensure
clear_pool
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")
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.instance_name).to eq('SidekiqStatus')
end
end
it_behaves_like 'multi store feature flags', :use_primary_and_secondary_stores_for_sidekiq_status,
:use_primary_store_as_default_for_sidekiq_status
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