Commit 7f674389 authored by Thong Kuah's avatar Thong Kuah

Fix disable_prepared_statements clobbering pool size

Use a fresh config when using with establish_connection
parent 1d854f3e
...@@ -34,11 +34,14 @@ module Gitlab ...@@ -34,11 +34,14 @@ module Gitlab
Gitlab::Runtime.max_threads + headroom Gitlab::Runtime.max_threads + headroom
end end
def config def uncached_config
@config ||=
scope.connection_db_config.configuration_hash.with_indifferent_access scope.connection_db_config.configuration_hash.with_indifferent_access
end end
def config
@config ||= uncached_config
end
def pool_size def pool_size
config[:pool] || default_pool_size config[:pool] || default_pool_size
end end
...@@ -69,7 +72,7 @@ module Gitlab ...@@ -69,7 +72,7 @@ module Gitlab
# Disables prepared statements for the current database connection. # Disables prepared statements for the current database connection.
def disable_prepared_statements def disable_prepared_statements
scope.establish_connection(config.merge(prepared_statements: false)) scope.establish_connection(uncached_config.merge(prepared_statements: false))
end end
def read_only? def read_only?
......
...@@ -140,6 +140,19 @@ RSpec.describe Gitlab::Database::Connection do ...@@ -140,6 +140,19 @@ RSpec.describe Gitlab::Database::Connection do
expect(connection.scope.connection.prepared_statements).to eq(false) expect(connection.scope.connection.prepared_statements).to eq(false)
end end
context 'with dynamic connection pool size' do
before do
connection.scope.establish_connection(connection.config.merge(pool: 7))
end
it 'retains the set pool size' do
connection.disable_prepared_statements
expect(connection.scope.connection.prepared_statements).to eq(false)
expect(connection.scope.connection.pool.size).to eq(7)
end
end
end end
describe '#read_only?' do describe '#read_only?' do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment