1
0
Fork 0
mirror of https://github.com/mperham/sidekiq.git synced 2022-11-09 13:52:34 -05:00

Log retry delay failures and fallback to the default

This commit is contained in:
Justin Mazzi 2013-06-25 12:35:11 -04:00
parent 6d023a61b9
commit 8983f4446a
2 changed files with 36 additions and 3 deletions

View file

@ -111,13 +111,19 @@ module Sidekiq
# delayed_job uses the same basic formula # delayed_job uses the same basic formula
def seconds_to_delay(worker, count) def seconds_to_delay(worker, count)
if worker.sidekiq_retry_with? default_retry_in = (count ** 4) + 15 + (rand(30)*(count+1))
worker.sidekiq_retry_with.call(count)
else
(count ** 4) + 15 + (rand(30)*(count+1))
end
end
if worker.sidekiq_retry_with?
begin
worker.sidekiq_retry_with.call(count)
rescue Exception => e
logger.error { "Failure scheduling retry using the defined `sidekiq_retry_in`! #{e.message} "}
default_retry_in
end
else
default_retry_in
end
end
end end
end end
end end

View file

@ -205,6 +205,17 @@ class TestRetry < Minitest::Test
end end
describe "custom retry delay" do describe "custom retry delay" do
before do
@old_logger = Sidekiq.logger
@tmp_log_path = '/tmp/sidekiq-retries.log'
Sidekiq.logger = Logger.new(@tmp_log_path)
end
after do
Sidekiq.logger = @old_logger
Sidekiq.options.delete(:logfile)
File.unlink @tmp_log_path if File.exists?(@tmp_log_path)
end
let(:custom_worker) do let(:custom_worker) do
Class.new do Class.new do
@ -216,6 +227,16 @@ class TestRetry < Minitest::Test
end end
end end
let(:error_worker) do
Class.new do
include ::Sidekiq::Worker
sidekiq_retry_in do |count|
count / 0
end
end
end
let(:handler){ Sidekiq::Middleware::Server::RetryJobs.new } let(:handler){ Sidekiq::Middleware::Server::RetryJobs.new }
it "retries with a default delay" do it "retries with a default delay" do
@ -225,6 +246,12 @@ class TestRetry < Minitest::Test
it "retries with a custom delay" do it "retries with a custom delay" do
assert_equal 4, handler.seconds_to_delay(custom_worker, 2) assert_equal 4, handler.seconds_to_delay(custom_worker, 2)
end end
it "falls back to the default retry on exception" do
refute_equal 4, handler.seconds_to_delay(error_worker, 2)
assert_match(/Failure scheduling retry using the defined `sidekiq_retry_in`/,
File.read(@tmp_log_path), 'Log entry missing for sidekiq_retry_in')
end
end end
end end