diff options
author | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2012-07-22 08:56:30 -0700 |
---|---|---|
committer | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2012-07-22 08:56:30 -0700 |
commit | 61be3401eec9d92d4248faddd82586bf40117b5b (patch) | |
tree | 489b98e5f01a5319a8d5dd08984536028e4665e7 /activerecord/lib | |
parent | 440a5ebd7a72fca1e655e5f4ff98435eddc4750a (diff) | |
parent | 8ca93c78832f4fdc78320e3f73ffd07bb71ce196 (diff) | |
download | rails-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.rb | 14 |
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 |