diff options
author | Aidan Haran <aidanharan@Aidans-MacBook-Pro.local> | 2017-09-16 19:59:32 +0100 |
---|---|---|
committer | Aidan Haran <aidanharan@Aidans-MacBook-Pro.local> | 2017-09-16 19:59:32 +0100 |
commit | 3291fa3630c456450f8c6a9b771f77c293d036cd (patch) | |
tree | d8b3a6311df9b233955209d6c33f0fa07c2c7285 /activejob/test | |
parent | 34956f7422798f27f8926544d58771042f6f1c3a (diff) | |
download | rails-3291fa3630c456450f8c6a9b771f77c293d036cd.tar.gz rails-3291fa3630c456450f8c6a9b771f77c293d036cd.tar.bz2 rails-3291fa3630c456450f8c6a9b771f77c293d036cd.zip |
Allow for custom handling of exceptions that are discarded
Diffstat (limited to 'activejob/test')
-rw-r--r-- | activejob/test/cases/exceptions_test.rb | 7 | ||||
-rw-r--r-- | activejob/test/jobs/retry_job.rb | 2 |
2 files changed, 9 insertions, 0 deletions
diff --git a/activejob/test/cases/exceptions_test.rb b/activejob/test/cases/exceptions_test.rb index 7a3c372143..7b8f1dcca7 100644 --- a/activejob/test/cases/exceptions_test.rb +++ b/activejob/test/cases/exceptions_test.rb @@ -58,6 +58,13 @@ class ExceptionsTest < ActiveJob::TestCase end end + test "custom handling of discarded job" do + perform_enqueued_jobs do + RetryJob.perform_later "CustomDiscardableError", 2 + assert_equal "Dealt with a job that was discarded in a custom way", JobBuffer.last_value + end + end + test "custom handling of job that exceeds retry attempts" do perform_enqueued_jobs do RetryJob.perform_later "CustomCatchError", 6 diff --git a/activejob/test/jobs/retry_job.rb b/activejob/test/jobs/retry_job.rb index a12d09779b..2b22186f0a 100644 --- a/activejob/test/jobs/retry_job.rb +++ b/activejob/test/jobs/retry_job.rb @@ -10,6 +10,7 @@ class ExponentialWaitTenAttemptsError < StandardError; end class CustomWaitTenAttemptsError < StandardError; end class CustomCatchError < StandardError; end class DiscardableError < StandardError; end +class CustomDiscardableError < StandardError; end class RetryJob < ActiveJob::Base retry_on DefaultsError @@ -19,6 +20,7 @@ class RetryJob < ActiveJob::Base retry_on CustomWaitTenAttemptsError, wait: ->(executions) { executions * 2 }, attempts: 10 retry_on(CustomCatchError) { |job, exception| JobBuffer.add("Dealt with a job that failed to retry in a custom way after #{job.arguments.second} attempts") } discard_on DiscardableError + discard_on(CustomDiscardableError) { |job, exception| JobBuffer.add("Dealt with a job that was discarded in a custom way") } def perform(raising, attempts) if executions < attempts |