# frozen_string_literal: true require 'spec_helper' RSpec.describe Gitlab::Redis::DbLoadBalancing, feature_category: :scalability do include_examples "redis_new_instance_shared_examples", 'db_load_balancing', Gitlab::Redis::SharedState 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" } subject { described_class.pool } before do allow(described_class).to receive(:config_file_name).and_return(config_new_format_host) # 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(mktmpdir) allow(Gitlab::Redis::SharedState).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") expect(redis_instance.secondary_store.connection[:id]).to eq("unix:///path/to/redis.sock/0") expect(redis_instance.instance_name).to eq('DbLoadBalancing') end end it_behaves_like 'multi store feature flags', :use_primary_and_secondary_stores_for_db_load_balancing, :use_primary_store_as_default_for_db_load_balancing end end