aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib
diff options
context:
space:
mode:
authorRafael Mendonça França <rafaelmfranca@gmail.com>2012-07-22 08:56:30 -0700
committerRafael Mendonça França <rafaelmfranca@gmail.com>2012-07-22 08:56:30 -0700
commit61be3401eec9d92d4248faddd82586bf40117b5b (patch)
tree489b98e5f01a5319a8d5dd08984536028e4665e7 /activerecord/lib
parent440a5ebd7a72fca1e655e5f4ff98435eddc4750a (diff)
parent8ca93c78832f4fdc78320e3f73ffd07bb71ce196 (diff)
downloadrails-61be3401eec9d92d4248faddd82586bf40117b5b.tar.gz
rails-61be3401eec9d92d4248faddd82586bf40117b5b.tar.bz2
rails-61be3401eec9d92d4248faddd82586bf40117b5b.zip
Merge pull request #7130 from kennyj/fix_restoring_query_cache
Restore connection_id on error.
Diffstat (limited to 'activerecord/lib')
-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