diff options
author | Hemant Kumar <hkumar@crri.co.in> | 2010-09-30 12:12:23 +0530 |
---|---|---|
committer | Aaron Patterson <aaron.patterson@gmail.com> | 2010-10-06 14:45:56 -0600 |
commit | 2a04110f266b6ccaf94aeeae224af578a9620fbd (patch) | |
tree | bb9c08186fddbe3af7063faff9e478d0098f0c6f /activerecord/test | |
parent | a0552d653b00e2e5b77e086b155e89fa22e4d6ed (diff) | |
download | rails-2a04110f266b6ccaf94aeeae224af578a9620fbd.tar.gz rails-2a04110f266b6ccaf94aeeae224af578a9620fbd.tar.bz2 rails-2a04110f266b6ccaf94aeeae224af578a9620fbd.zip |
fix ruby 1.9 deadlock problem, fixes #5736 add connection pool tests
Diffstat (limited to 'activerecord/test')
-rw-r--r-- | activerecord/test/cases/connection_pool_test.rb | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/activerecord/test/cases/connection_pool_test.rb b/activerecord/test/cases/connection_pool_test.rb index 82b3c36ed2..f0ec5c751c 100644 --- a/activerecord/test/cases/connection_pool_test.rb +++ b/activerecord/test/cases/connection_pool_test.rb @@ -26,6 +26,35 @@ module ActiveRecord "threads should have been removed") assert_equal pool.checkins.length, threads.length end + + def test_checkout_behaviour + pool = ConnectionPool.new ActiveRecord::Base.connection_pool.spec + connection = pool.connection + assert_not_nil connection + threads = [] + 4.times do |i| + threads << Thread.new(i) do |pool_count| + connection = pool.connection + assert_not_nil connection + end + end + + threads.each {|t| t.join} + + Thread.new do + threads.each do |t| + thread_ids = pool.instance_variable_get(:@reserved_connections).keys + assert thread_ids.include?(t.object_id) + end + + pool.connection + threads.each do |t| + thread_ids = pool.instance_variable_get(:@reserved_connections).keys + assert !thread_ids.include?(t.object_id) + end + end.join() + + end end end end |