未验证 提交 3bf33d7c 编写于 作者: S Steve S

Move ActiveJob retry and discard logging into log subscriber

上级 26dc9bc8
...@@ -48,11 +48,11 @@ def retry_on(*exceptions, wait: 3.seconds, attempts: 5, queue: nil, priority: ni ...@@ -48,11 +48,11 @@ def retry_on(*exceptions, wait: 3.seconds, attempts: 5, queue: nil, priority: ni
job: self, job: self,
adapter: self.class.queue_adapter, adapter: self.class.queue_adapter,
error: error, error: error,
wait: wait
} }
if executions < attempts if executions < attempts
ActiveSupport::Notifications.instrument("enqueue_retry.active_job", payload) do ActiveSupport::Notifications.instrument("enqueue_retry.active_job", payload) do
logger.error "Retrying #{self.class} in #{wait} seconds, due to a #{error.class}. The original exception was #{error.cause.inspect}."
retry_job wait: determine_delay(wait), queue: queue, priority: priority retry_job wait: determine_delay(wait), queue: queue, priority: priority
end end
else else
...@@ -61,7 +61,7 @@ def retry_on(*exceptions, wait: 3.seconds, attempts: 5, queue: nil, priority: ni ...@@ -61,7 +61,7 @@ def retry_on(*exceptions, wait: 3.seconds, attempts: 5, queue: nil, priority: ni
yield self, error yield self, error
end end
else else
logger.error "Stopped retrying #{self.class} due to a #{error.class}, which reoccurred on #{executions} attempts. The original exception was #{error.cause.inspect}." ActiveSupport::Notifications.instrument("retry_stopped.active_job", payload)
raise error raise error
end end
end end
...@@ -91,14 +91,12 @@ def discard_on(*exceptions) ...@@ -91,14 +91,12 @@ def discard_on(*exceptions)
payload = { payload = {
job: self, job: self,
adapter: self.class.queue_adapter, adapter: self.class.queue_adapter,
error: error, error: error
} }
ActiveSupport::Notifications.instrument("discard.active_job", payload) do ActiveSupport::Notifications.instrument("discard.active_job", payload) do
if block_given? if block_given?
yield self, error yield self, error
else
logger.error "Discarded #{self.class} due to a #{error.class}. The original exception was #{error.cause.inspect}."
end end
end end
end end
......
...@@ -88,6 +88,34 @@ def perform(event) ...@@ -88,6 +88,34 @@ def perform(event)
end end
end end
def enqueue_retry(event)
job = event.payload[:job]
ex = event.payload[:error]
wait = event.payload[:wait]
error do
"Retrying #{job.class} in #{wait} seconds, due to a #{ex.class}. The original exception was #{ex.cause.inspect}."
end
end
def retry_stopped(event)
job = event.payload[:job]
ex = event.payload[:error]
error do
"Stopped retrying #{job.class} due to a #{ex.class}, which reoccurred on #{job.executions} attempts. The original exception was #{ex.cause.inspect}."
end
end
def discard(event)
job = event.payload[:job]
ex = event.payload[:error]
error do
"Discarded #{job.class} due to a #{ex.class}. The original exception was #{ex.cause.inspect}."
end
end
private private
def queue_name(event) def queue_name(event)
event.payload[:adapter].class.name.demodulize.remove("Adapter") + "(#{event.payload[:job].queue_name})" event.payload[:adapter].class.name.demodulize.remove("Adapter") + "(#{event.payload[:job].queue_name})"
......
...@@ -8,9 +8,11 @@ ...@@ -8,9 +8,11 @@
require "jobs/overridden_logging_job" require "jobs/overridden_logging_job"
require "jobs/nested_job" require "jobs/nested_job"
require "jobs/rescue_job" require "jobs/rescue_job"
require "jobs/retry_job"
require "models/person" require "models/person"
class LoggingTest < ActiveSupport::TestCase class LoggingTest < ActiveSupport::TestCase
include ActiveJob::TestHelper
include ActiveSupport::LogSubscriber::TestHelper include ActiveSupport::LogSubscriber::TestHelper
include ActiveSupport::Logger::Severity include ActiveSupport::Logger::Severity
...@@ -59,14 +61,18 @@ def test_uses_active_job_as_tag ...@@ -59,14 +61,18 @@ def test_uses_active_job_as_tag
end end
def test_uses_job_name_as_tag def test_uses_job_name_as_tag
perform_enqueued_jobs do
LoggingJob.perform_later "Dummy" LoggingJob.perform_later "Dummy"
assert_match(/\[LoggingJob\]/, @logger.messages) assert_match(/\[LoggingJob\]/, @logger.messages)
end end
end
def test_uses_job_id_as_tag def test_uses_job_id_as_tag
perform_enqueued_jobs do
LoggingJob.perform_later "Dummy" LoggingJob.perform_later "Dummy"
assert_match(/\[LOGGING-JOB-ID\]/, @logger.messages) assert_match(/\[LOGGING-JOB-ID\]/, @logger.messages)
end end
end
def test_logs_correct_queue_name def test_logs_correct_queue_name
original_queue_name = LoggingJob.queue_name original_queue_name = LoggingJob.queue_name
...@@ -78,20 +84,24 @@ def test_logs_correct_queue_name ...@@ -78,20 +84,24 @@ def test_logs_correct_queue_name
end end
def test_globalid_parameter_logging def test_globalid_parameter_logging
perform_enqueued_jobs do
person = Person.new(123) person = Person.new(123)
LoggingJob.perform_later person LoggingJob.perform_later person
assert_match(%r{Enqueued.*gid://aj/Person/123}, @logger.messages) assert_match(%r{Enqueued.*gid://aj/Person/123}, @logger.messages)
assert_match(%r{Dummy, here is it: #<Person:.*>}, @logger.messages) assert_match(%r{Dummy, here is it: #<Person:.*>}, @logger.messages)
assert_match(%r{Performing.*gid://aj/Person/123}, @logger.messages) assert_match(%r{Performing.*gid://aj/Person/123}, @logger.messages)
end end
end
def test_globalid_nested_parameter_logging def test_globalid_nested_parameter_logging
perform_enqueued_jobs do
person = Person.new(123) person = Person.new(123)
LoggingJob.perform_later(person: person) LoggingJob.perform_later(person: person)
assert_match(%r{Enqueued.*gid://aj/Person/123}, @logger.messages) assert_match(%r{Enqueued.*gid://aj/Person/123}, @logger.messages)
assert_match(%r{Dummy, here is it: .*#<Person:.*>}, @logger.messages) assert_match(%r{Dummy, here is it: .*#<Person:.*>}, @logger.messages)
assert_match(%r{Performing.*gid://aj/Person/123}, @logger.messages) assert_match(%r{Performing.*gid://aj/Person/123}, @logger.messages)
end end
end
def test_enqueue_job_logging def test_enqueue_job_logging
events = subscribed { HelloJob.perform_later "Cristian" } events = subscribed { HelloJob.perform_later "Cristian" }
...@@ -102,13 +112,16 @@ def test_enqueue_job_logging ...@@ -102,13 +112,16 @@ def test_enqueue_job_logging
end end
def test_perform_job_logging def test_perform_job_logging
perform_enqueued_jobs do
LoggingJob.perform_later "Dummy" LoggingJob.perform_later "Dummy"
assert_match(/Performing LoggingJob \(Job ID: .*?\) from .*? with arguments:.*Dummy/, @logger.messages) assert_match(/Performing LoggingJob \(Job ID: .*?\) from .*? with arguments:.*Dummy/, @logger.messages)
assert_match(/Dummy, here is it: Dummy/, @logger.messages) assert_match(/Dummy, here is it: Dummy/, @logger.messages)
assert_match(/Performed LoggingJob \(Job ID: .*?\) from .*? in .*ms/, @logger.messages) assert_match(/Performed LoggingJob \(Job ID: .*?\) from .*? in .*ms/, @logger.messages)
end end
end
def test_perform_nested_jobs_logging def test_perform_nested_jobs_logging
perform_enqueued_jobs do
NestedJob.perform_later NestedJob.perform_later
assert_match(/\[LoggingJob\] \[.*?\]/, @logger.messages) assert_match(/\[LoggingJob\] \[.*?\]/, @logger.messages)
assert_match(/\[ActiveJob\] Enqueued NestedJob \(Job ID: .*\) to/, @logger.messages) assert_match(/\[ActiveJob\] Enqueued NestedJob \(Job ID: .*\) to/, @logger.messages)
...@@ -119,6 +132,7 @@ def test_perform_nested_jobs_logging ...@@ -119,6 +132,7 @@ def test_perform_nested_jobs_logging
assert_match(/\[ActiveJob\].*\[LoggingJob\] \[LOGGING-JOB-ID\] Performed LoggingJob \(Job ID: .*?\) from .* in/, @logger.messages) assert_match(/\[ActiveJob\].*\[LoggingJob\] \[LOGGING-JOB-ID\] Performed LoggingJob \(Job ID: .*?\) from .* in/, @logger.messages)
assert_match(/\[ActiveJob\] \[NestedJob\] \[NESTED-JOB-ID\] Performed NestedJob \(Job ID: .*?\) from .* in/, @logger.messages) assert_match(/\[ActiveJob\] \[NestedJob\] \[NESTED-JOB-ID\] Performed NestedJob \(Job ID: .*?\) from .* in/, @logger.messages)
end end
end
def test_enqueue_at_job_logging def test_enqueue_at_job_logging
events = subscribed { HelloJob.set(wait_until: 24.hours.from_now).perform_later "Cristian" } events = subscribed { HelloJob.set(wait_until: 24.hours.from_now).perform_later "Cristian" }
...@@ -151,4 +165,35 @@ def test_job_error_logging ...@@ -151,4 +165,35 @@ def test_job_error_logging
assert_match(/Performing RescueJob \(Job ID: .*?\) from .*? with arguments:.*other/, @logger.messages) assert_match(/Performing RescueJob \(Job ID: .*?\) from .*? with arguments:.*other/, @logger.messages)
assert_match(/Error performing RescueJob \(Job ID: .*?\) from .*? in .*ms: RescueJob::OtherError \(Bad hair\):\n.*\brescue_job\.rb:\d+:in `perform'/, @logger.messages) assert_match(/Error performing RescueJob \(Job ID: .*?\) from .*? in .*ms: RescueJob::OtherError \(Bad hair\):\n.*\brescue_job\.rb:\d+:in `perform'/, @logger.messages)
end end
def test_enqueue_retry_logging
perform_enqueued_jobs do
RetryJob.perform_later "DefaultsError", 2
assert_match(/Retrying RetryJob in \d+ seconds, due to a DefaultsError\. The original exception was nil\./, @logger.messages)
end
end
def test_retry_stopped_logging
perform_enqueued_jobs do
RetryJob.perform_later "CustomCatchError", 6
assert_match(/Stopped retrying RetryJob due to a CustomCatchError, which reoccurred on \d+ attempts\. The original exception was #<CustomCatchError: CustomCatchError>\./, @logger.messages)
end
end
def test_retry_stopped_logging_without_block
perform_enqueued_jobs do
begin
RetryJob.perform_later "DefaultsError", 6
rescue DefaultsError
assert_match(/Stopped retrying RetryJob due to a DefaultsError, which reoccurred on \d+ attempts\. The original exception was #<DefaultsError: DefaultsError>\./, @logger.messages)
end
end
end
def test_discard_logging
perform_enqueued_jobs do
RetryJob.perform_later "DiscardableError", 2
assert_match(/Discarded RetryJob due to a DiscardableError\. The original exception was nil\./, @logger.messages)
end
end
end end
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册