Commit 1ef5bc11 authored by Fabio Pitino's avatar Fabio Pitino

Capture errors raised for a batch when resetting CI minutes

When sending the errors being raised during a batch reset of
CI minutes, we were not capturing the actual error message.
This made debugging hard when a batch failed to be updated.
parent 2f94378e
...@@ -35,8 +35,8 @@ module Ci ...@@ -35,8 +35,8 @@ module Ci
reset_shared_runners_seconds!(namespaces) reset_shared_runners_seconds!(namespaces)
reset_ci_minutes_notifications!(namespaces) reset_ci_minutes_notifications!(namespaces)
end end
rescue ActiveRecord::ActiveRecordError rescue ActiveRecord::ActiveRecordError => e
@errors << { count: namespaces.size, first_id: namespaces.first.id, last_id: namespaces.last.id } @errors << { count: namespaces.size, first_id: namespaces.first.id, last_id: namespaces.last.id, error: e.message }
end end
# This service is responsible for the logic that recalculates the extra shared runners # This service is responsible for the logic that recalculates the extra shared runners
......
...@@ -4,6 +4,7 @@ module Ci ...@@ -4,6 +4,7 @@ module Ci
class BatchResetMinutesWorker class BatchResetMinutesWorker
include ApplicationWorker include ApplicationWorker
sidekiq_options retry: 10
feature_category :continuous_integration feature_category :continuous_integration
idempotent! idempotent!
......
...@@ -138,7 +138,7 @@ RSpec.describe Ci::Minutes::BatchResetService do ...@@ -138,7 +138,7 @@ RSpec.describe Ci::Minutes::BatchResetService do
let(:ids_range) { nil } let(:ids_range) { nil }
before do before do
expect(Namespace).to receive(:transaction).once.ordered.and_raise(ActiveRecord::ActiveRecordError) expect(Namespace).to receive(:transaction).once.ordered.and_raise(ActiveRecord::ActiveRecordError, 'something went wrong')
expect(Namespace).to receive(:transaction).once.ordered.and_call_original expect(Namespace).to receive(:transaction).once.ordered.and_call_original
end end
...@@ -157,7 +157,7 @@ RSpec.describe Ci::Minutes::BatchResetService do ...@@ -157,7 +157,7 @@ RSpec.describe Ci::Minutes::BatchResetService do
Ci::Minutes::BatchResetService::BatchNotResetError.new( Ci::Minutes::BatchResetService::BatchNotResetError.new(
'Some namespace shared runner minutes were not reset.' 'Some namespace shared runner minutes were not reset.'
), ),
{ namespace_ranges: [{ count: 3, first_id: 1, last_id: 3 }] } { namespace_ranges: [{ count: 3, first_id: 1, last_id: 3, error: 'something went wrong' }] }
).once.and_call_original ).once.and_call_original
expect { subject }.to raise_error(Ci::Minutes::BatchResetService::BatchNotResetError) expect { subject }.to raise_error(Ci::Minutes::BatchResetService::BatchNotResetError)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment