diff options
author | Pratik Naik <pratiknaik@gmail.com> | 2015-10-12 12:33:48 -0500 |
---|---|---|
committer | Pratik Naik <pratiknaik@gmail.com> | 2015-10-12 12:33:48 -0500 |
commit | d222f7de572f28fc2fa185e9f21cac6f7e6c84f0 (patch) | |
tree | bc3b9edb6e85119f172c1367fd96826367b1948d /lib/action_cable/server | |
parent | aa3c1154edfacecbbf676af4d8728d8674d97cf4 (diff) | |
download | rails-d222f7de572f28fc2fa185e9f21cac6f7e6c84f0.tar.gz rails-d222f7de572f28fc2fa185e9f21cac6f7e6c84f0.tar.bz2 rails-d222f7de572f28fc2fa185e9f21cac6f7e6c84f0.zip |
Make sure active record queries are logged with the current connection tags
Diffstat (limited to 'lib/action_cable/server')
-rw-r--r-- | lib/action_cable/server/worker.rb | 7 | ||||
-rw-r--r-- | lib/action_cable/server/worker/active_record_connection_management.rb (renamed from lib/action_cable/server/worker/clear_database_connections.rb) | 4 |
2 files changed, 8 insertions, 3 deletions
diff --git a/lib/action_cable/server/worker.rb b/lib/action_cable/server/worker.rb index d7823ecf93..91496775b8 100644 --- a/lib/action_cable/server/worker.rb +++ b/lib/action_cable/server/worker.rb @@ -5,10 +5,13 @@ module ActionCable include ActiveSupport::Callbacks include Celluloid + attr_reader :connection define_callbacks :work - include ClearDatabaseConnections + include ActiveRecordConnectionManagement def invoke(receiver, method, *args) + @connection = receiver + run_callbacks :work do receiver.send method, *args end @@ -20,6 +23,8 @@ module ActionCable end def run_periodic_timer(channel, callback) + @connection = channel.connection + run_callbacks :work do callback.respond_to?(:call) ? channel.instance_exec(&callback) : channel.send(callback) end diff --git a/lib/action_cable/server/worker/clear_database_connections.rb b/lib/action_cable/server/worker/active_record_connection_management.rb index 722d363a41..1ede0095f8 100644 --- a/lib/action_cable/server/worker/clear_database_connections.rb +++ b/lib/action_cable/server/worker/active_record_connection_management.rb @@ -2,7 +2,7 @@ module ActionCable module Server class Worker # Clear active connections between units of work so the long-running channel or connection processes do not hoard connections. - module ClearDatabaseConnections + module ActiveRecordConnectionManagement extend ActiveSupport::Concern included do @@ -12,7 +12,7 @@ module ActionCable end def with_database_connections - yield + ActiveRecord::Base.logger.tagged(*connection.logger.tags) { yield } ensure ActiveRecord::Base.clear_active_connections! end |