2005-07-10 00:54:34 -04:00
|
|
|
require 'abstract_unit'
|
2005-09-29 20:58:26 -04:00
|
|
|
require 'fixtures/topic'
|
2006-06-19 18:48:51 -04:00
|
|
|
require 'fixtures/reply'
|
2005-07-10 00:54:34 -04:00
|
|
|
|
2006-04-27 18:39:45 -04:00
|
|
|
unless %w(FrontBase).include? ActiveRecord::Base.connection.adapter_name
|
|
|
|
class ThreadedConnectionsTest < Test::Unit::TestCase
|
|
|
|
self.use_transactional_fixtures = false
|
2005-07-10 00:54:34 -04:00
|
|
|
|
2006-04-27 18:39:45 -04:00
|
|
|
fixtures :topics
|
2005-07-10 00:54:34 -04:00
|
|
|
|
|
|
|
def setup
|
|
|
|
@connection = ActiveRecord::Base.remove_connection
|
|
|
|
@connections = []
|
2006-03-13 12:28:55 -05:00
|
|
|
@allow_concurrency = ActiveRecord::Base.allow_concurrency
|
|
|
|
end
|
|
|
|
|
|
|
|
def teardown
|
|
|
|
# clear the connection cache
|
|
|
|
ActiveRecord::Base.send(:clear_all_cached_connections!)
|
|
|
|
# set allow_concurrency to saved value
|
|
|
|
ActiveRecord::Base.allow_concurrency = @allow_concurrency
|
|
|
|
# reestablish old connection
|
|
|
|
ActiveRecord::Base.establish_connection(@connection)
|
2005-07-10 00:54:34 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def gather_connections(use_threaded_connections)
|
2005-10-12 18:37:28 -04:00
|
|
|
ActiveRecord::Base.allow_concurrency = use_threaded_connections
|
2005-07-10 00:54:34 -04:00
|
|
|
ActiveRecord::Base.establish_connection(@connection)
|
|
|
|
|
2006-04-27 18:39:45 -04:00
|
|
|
5.times do
|
|
|
|
Thread.new do
|
|
|
|
Topic.find :first
|
|
|
|
@connections << ActiveRecord::Base.active_connections.values.first
|
|
|
|
end.join
|
|
|
|
end
|
2005-07-10 00:54:34 -04:00
|
|
|
end
|
|
|
|
|
2006-04-27 18:39:45 -04:00
|
|
|
def test_threaded_connections
|
|
|
|
gather_connections(true)
|
|
|
|
assert_equal @connections.uniq.length, 5
|
|
|
|
end
|
2005-07-10 00:54:34 -04:00
|
|
|
|
2006-04-27 18:39:45 -04:00
|
|
|
def test_unthreaded_connections
|
|
|
|
gather_connections(false)
|
|
|
|
assert_equal @connections.uniq.length, 1
|
|
|
|
end
|
2005-07-10 00:54:34 -04:00
|
|
|
end
|
|
|
|
end
|