aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarek Pieczyk <codebaker95@gmail.com>2015-09-06 23:39:42 +0200
committerMarek Pieczyk <codebaker95@gmail.com>2015-09-08 23:28:12 +0200
commit26f37f7c401d95acb582dbb1d820e2333f84f217 (patch)
tree87e4545da06d77b6203e3daaa04c4dcd023e8370
parent997acb9aadab4df57b5a4ce88ddce3ec9d5f5f45 (diff)
downloadrails-26f37f7c401d95acb582dbb1d820e2333f84f217.tar.gz
rails-26f37f7c401d95acb582dbb1d820e2333f84f217.tar.bz2
rails-26f37f7c401d95acb582dbb1d820e2333f84f217.zip
Properly log nested parameters to Active Job
Refactor arguments logging method for Active Job
-rw-r--r--activejob/lib/active_job/logging.rb16
-rw-r--r--activejob/test/cases/logging_test.rb8
2 files changed, 23 insertions, 1 deletions
diff --git a/activejob/lib/active_job/logging.rb b/activejob/lib/active_job/logging.rb
index 54774db601..d72e1bdfce 100644
--- a/activejob/lib/active_job/logging.rb
+++ b/activejob/lib/active_job/logging.rb
@@ -1,3 +1,4 @@
+require 'active_support/core_ext/hash/transform_values'
require 'active_support/core_ext/string/filters'
require 'active_support/tagged_logging'
require 'active_support/logger'
@@ -87,12 +88,25 @@ module ActiveJob
def args_info(job)
if job.arguments.any?
' with arguments: ' +
- job.arguments.map { |arg| arg.try(:to_global_id).try(:to_s) || arg.inspect }.join(', ')
+ job.arguments.map { |arg| format(arg).inspect }.join(', ')
else
''
end
end
+ def format(arg)
+ case arg
+ when Hash
+ arg.transform_values { |value| format(value) }
+ when Array
+ arg.map { |value| format(value) }
+ when GlobalID::Identification
+ arg.to_global_id rescue arg
+ else
+ arg
+ end
+ end
+
def scheduled_at(event)
Time.at(event.payload[:job].scheduled_at).utc
end
diff --git a/activejob/test/cases/logging_test.rb b/activejob/test/cases/logging_test.rb
index b18be553ec..820e9112de 100644
--- a/activejob/test/cases/logging_test.rb
+++ b/activejob/test/cases/logging_test.rb
@@ -74,6 +74,14 @@ class LoggingTest < ActiveSupport::TestCase
assert_match(%r{Performing.*gid://aj/Person/123}, @logger.messages)
end
+ def test_globalid_nested_parameter_logging
+ person = Person.new(123)
+ LoggingJob.perform_later(person: person)
+ assert_match(%r{Enqueued.*gid://aj/Person/123}, @logger.messages)
+ assert_match(%r{Dummy, here is it: .*#<Person:.*>}, @logger.messages)
+ assert_match(%r{Performing.*gid://aj/Person/123}, @logger.messages)
+ end
+
def test_enqueue_job_logging
HelloJob.perform_later "Cristian"
assert_match(/Enqueued HelloJob \(Job ID: .*?\) to .*?:.*Cristian/, @logger.messages)