# frozen_string_literal: true module ConnectionPoolBehavior def test_connection_pool Thread.report_on_exception, original_report_on_exception = false, Thread.report_on_exception threads = [] emulating_latency do begin cache = ActiveSupport::Cache.lookup_store(store, { pool_size: 2, pool_timeout: 1 }.merge(store_options)) cache.clear assert_raises Timeout::Error do # One of the three threads will fail in 1 second because our pool size # is only two. 3.times do threads << Thread.new do cache.read("latency") end end threads.each(&:join) end ensure threads.each(&:kill) end end ensure Thread.report_on_exception = original_report_on_exception end def test_no_connection_pool threads = [] emulating_latency do begin cache = ActiveSupport::Cache.lookup_store(store, store_options) cache.clear assert_nothing_raised do # Default connection pool size is 5, assuming 10 will make sure that # the connection pool isn't used at all. 10.times do threads << Thread.new do cache.read("latency") end end threads.each(&:join) end ensure threads.each(&:kill) end end end private def store_options; {}; end end