aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib/active_record
diff options
context:
space:
mode:
authorkennyj <kennyj@gmail.com>2012-07-23 00:46:00 +0900
committerkennyj <kennyj@gmail.com>2012-07-23 00:46:00 +0900
commit8ca93c78832f4fdc78320e3f73ffd07bb71ce196 (patch)
treeef52c8b9496451ae92f53c0d6a6b9903a7df631c /activerecord/lib/active_record
parent1b2a7bad671cf39252dc539a673cd217a25235a8 (diff)
downloadrails-8ca93c78832f4fdc78320e3f73ffd07bb71ce196.tar.gz
rails-8ca93c78832f4fdc78320e3f73ffd07bb71ce196.tar.bz2
rails-8ca93c78832f4fdc78320e3f73ffd07bb71ce196.zip
Restore connection_id on error.
Diffstat (limited to 'activerecord/lib/active_record')
-rw-r--r--activerecord/lib/active_record/query_cache.rb14
1 files changed, 10 insertions, 4 deletions
diff --git a/activerecord/lib/active_record/query_cache.rb b/activerecord/lib/active_record/query_cache.rb
index 9701898415..d64dee10fe 100644
--- a/activerecord/lib/active_record/query_cache.rb
+++ b/activerecord/lib/active_record/query_cache.rb
@@ -34,16 +34,22 @@ module ActiveRecord
response = @app.call(env)
response[2] = Rack::BodyProxy.new(response[2]) do
- ActiveRecord::Base.connection_id = connection_id
- ActiveRecord::Base.connection.clear_query_cache
- ActiveRecord::Base.connection.disable_query_cache! unless enabled
+ restore_query_cache_settings(connection_id, enabled)
end
response
rescue Exception => e
+ restore_query_cache_settings(connection_id, enabled)
+ raise e
+ end
+
+ private
+
+ def restore_query_cache_settings(connection_id, enabled)
+ ActiveRecord::Base.connection_id = connection_id
ActiveRecord::Base.connection.clear_query_cache
ActiveRecord::Base.connection.disable_query_cache! unless enabled
- raise e
end
+
end
end