2015-10-11 17:41:23 +08:00
|
|
|
require 'rails_helper'
|
2014-08-11 13:13:37 +08:00
|
|
|
|
|
|
|
describe 'pool drainer' do
|
|
|
|
let(:pool) do
|
|
|
|
ActiveRecord::Base.connection_pool
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'can correctly drain the connection pool' do
|
|
|
|
pool.drain
|
|
|
|
old = pool.connections.length
|
2015-01-10 00:34:37 +08:00
|
|
|
expect(old).to eq(1)
|
2014-08-11 13:13:37 +08:00
|
|
|
|
|
|
|
Thread.new do
|
|
|
|
conn = pool.checkout
|
|
|
|
pool.checkin conn
|
|
|
|
end.join
|
|
|
|
|
2017-07-28 09:20:09 +08:00
|
|
|
expect(pool.connections.length).to eq(old + 1)
|
2014-08-11 13:13:37 +08:00
|
|
|
pool.drain
|
2015-01-10 00:34:37 +08:00
|
|
|
expect(pool.connections.length).to eq(old)
|
2014-08-11 13:13:37 +08:00
|
|
|
end
|
|
|
|
|
|
|
|
it 'can drain with idle time setting' do
|
|
|
|
pool.drain
|
|
|
|
old = pool.connections.length
|
2015-01-10 00:34:37 +08:00
|
|
|
expect(old).to eq(1)
|
2014-08-11 13:13:37 +08:00
|
|
|
|
|
|
|
Thread.new do
|
|
|
|
conn = pool.checkout
|
|
|
|
pool.checkin conn
|
|
|
|
end.join
|
|
|
|
|
2017-07-28 09:20:09 +08:00
|
|
|
expect(pool.connections.length).to eq(old + 1)
|
2014-08-11 13:13:37 +08:00
|
|
|
pool.drain(1.minute)
|
2017-07-28 09:20:09 +08:00
|
|
|
expect(pool.connections.length).to eq(old + 1)
|
2014-08-11 13:13:37 +08:00
|
|
|
|
|
|
|
# make sure we don't corrupt internal state
|
|
|
|
20.times do
|
|
|
|
conn = pool.checkout
|
|
|
|
pool.checkin conn
|
|
|
|
pool.drain
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|