diff options
author | David Heinemeier Hansson <david@loudthinking.com> | 2005-07-10 04:54:34 +0000 |
---|---|---|
committer | David Heinemeier Hansson <david@loudthinking.com> | 2005-07-10 04:54:34 +0000 |
commit | 60499774c2a8ecd9d87b140ffbe24634559c3fcd (patch) | |
tree | e4e2a348e4dae4d107f020f9c21664a5e169b92c /activerecord/test | |
parent | e008bfd2d8e8e19eb94ddb49121820effe93d7f4 (diff) | |
download | rails-60499774c2a8ecd9d87b140ffbe24634559c3fcd.tar.gz rails-60499774c2a8ecd9d87b140ffbe24634559c3fcd.tar.bz2 rails-60499774c2a8ecd9d87b140ffbe24634559c3fcd.zip |
Fixed that each request with the WEBrick adapter would open a new database connection #1685 [Sam Stephenson]. Added ActiveRecord::Base.threaded_connections flag to turn off 1-connection per thread (required for thread safety). By default it's on, but WEBrick in Rails need it off #1685 [Sam Stephenson]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@1792 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activerecord/test')
-rw-r--r-- | activerecord/test/threaded_connections_test.rb | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/activerecord/test/threaded_connections_test.rb b/activerecord/test/threaded_connections_test.rb new file mode 100644 index 0000000000..29c16b1a5c --- /dev/null +++ b/activerecord/test/threaded_connections_test.rb @@ -0,0 +1,34 @@ +require 'abstract_unit' + +class ThreadedConnectionsTest < Test::Unit::TestCase + self.use_transactional_fixtures = false + + fixtures :topics + + def setup + @connection = ActiveRecord::Base.remove_connection + @connections = [] + end + + def gather_connections(use_threaded_connections) + ActiveRecord::Base.threaded_connections = use_threaded_connections + ActiveRecord::Base.establish_connection(@connection) + + 5.times do + Thread.new do + Topic.find :first + @connections << ActiveRecord::Base.active_connections.values.first + end.join + end + end + + def test_threaded_connections + gather_connections(true) + assert_equal @connections.uniq.length, 5 + end + + def test_unthreaded_connections + gather_connections(false) + assert_equal @connections.uniq.length, 1 + end +end |