Skip to content

Commit

Permalink
Merge pull request #28869 from eugeneius/query_cache_all_pools
Browse files Browse the repository at this point in the history
Enable query cache on all connection pools
  • Loading branch information
matthewd committed Nov 17, 2017
2 parents c39ed43 + 11e32c1 commit cd3c0fa
Show file tree
Hide file tree
Showing 2 changed files with 18 additions and 6 deletions.
15 changes: 9 additions & 6 deletions activerecord/lib/active_record/query_cache.rb
Expand Up @@ -26,16 +26,19 @@ def uncached(&block)
end

def self.run
caching_pool = ActiveRecord::Base.connection_pool
caching_was_enabled = caching_pool.query_cache_enabled
ActiveRecord::Base.connection_handler.connection_pool_list.map do |pool|
caching_was_enabled = pool.query_cache_enabled

caching_pool.enable_query_cache!
pool.enable_query_cache!

[caching_pool, caching_was_enabled]
[pool, caching_was_enabled]
end
end

def self.complete((caching_pool, caching_was_enabled))
caching_pool.disable_query_cache! unless caching_was_enabled
def self.complete(caching_pools)
caching_pools.each do |pool, caching_was_enabled|
pool.disable_query_cache! unless caching_was_enabled
end

ActiveRecord::Base.connection_handler.connection_pool_list.each do |pool|
pool.release_connection if pool.active_connection? && !pool.connection.transaction_open?
Expand Down
9 changes: 9 additions & 0 deletions activerecord/test/cases/query_cache_test.rb
Expand Up @@ -452,6 +452,15 @@ def test_query_caching_is_local_to_the_current_thread
end
end

def test_query_cache_is_enabled_on_all_connection_pools
middleware {
ActiveRecord::Base.connection_handler.connection_pool_list.each do |pool|
assert pool.query_cache_enabled
assert pool.connection.query_cache_enabled
end
}.call({})
end

private
def middleware(&app)
executor = Class.new(ActiveSupport::Executor)
Expand Down

0 comments on commit cd3c0fa

Please sign in to comment.