1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/activejob/test/jobs/retry_job.rb

30 lines
1.2 KiB
Ruby
Raw Normal View History

require_relative "../support/job_buffer"
require "active_support/core_ext/integer/inflections"
2016-08-01 19:09:16 -04:00
class DefaultsError < StandardError; end
class LongWaitError < StandardError; end
2016-08-01 19:09:16 -04:00
class ShortWaitTenAttemptsError < StandardError; end
class ExponentialWaitTenAttemptsError < StandardError; end
class CustomWaitTenAttemptsError < StandardError; end
class CustomCatchError < StandardError; end
2016-08-01 19:09:16 -04:00
class DiscardableError < StandardError; end
class RetryJob < ActiveJob::Base
2016-08-01 19:09:16 -04:00
retry_on DefaultsError
retry_on LongWaitError, wait: 1.hour, attempts: 10
2016-08-01 19:09:16 -04:00
retry_on ShortWaitTenAttemptsError, wait: 1.second, attempts: 10
retry_on ExponentialWaitTenAttemptsError, wait: :exponentially_longer, attempts: 10
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") }
2016-08-01 19:09:16 -04:00
discard_on DiscardableError
def perform(raising, attempts)
if executions < attempts
JobBuffer.add("Raised #{raising} for the #{executions.ordinalize} time")
raise raising.constantize
else
JobBuffer.add("Successfully completed job")
end
end
end