2019-12-21 20:55:43 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
2020-07-28 23:09:34 +05:30
|
|
|
RSpec.describe Gitlab::SidekiqLogging::ExceptionHandler do
|
2019-12-21 20:55:43 +05:30
|
|
|
describe '#call' do
|
|
|
|
let(:job) do
|
|
|
|
{
|
|
|
|
"class" => "TestWorker",
|
|
|
|
"args" => [1234, 'hello'],
|
|
|
|
"retry" => false,
|
|
|
|
"queue" => "cronjob:test_queue",
|
|
|
|
"queue_namespace" => "cronjob",
|
|
|
|
"jid" => "da883554ee4fe414012f5f42",
|
|
|
|
"correlation_id" => 'cid'
|
|
|
|
}
|
|
|
|
end
|
|
|
|
|
|
|
|
let(:exception_message) { 'An error was thrown' }
|
|
|
|
let(:backtrace) { caller }
|
|
|
|
let(:exception) { RuntimeError.new(exception_message) }
|
|
|
|
let(:logger) { double }
|
|
|
|
|
|
|
|
before do
|
|
|
|
allow(Sidekiq).to receive(:logger).and_return(logger)
|
|
|
|
allow(exception).to receive(:backtrace).and_return(backtrace)
|
|
|
|
end
|
|
|
|
|
|
|
|
subject { described_class.new.call(exception, { context: 'Test', job: job }) }
|
|
|
|
|
|
|
|
it 'logs job data into root tree' do
|
|
|
|
expected_data = job.merge(
|
|
|
|
error_class: 'RuntimeError',
|
|
|
|
error_message: exception_message,
|
|
|
|
context: 'Test',
|
2020-03-09 13:42:32 +05:30
|
|
|
error_backtrace: Gitlab::BacktraceCleaner.clean_backtrace(backtrace)
|
2019-12-21 20:55:43 +05:30
|
|
|
)
|
|
|
|
|
|
|
|
expect(logger).to receive(:warn).with(expected_data)
|
|
|
|
|
|
|
|
subject
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|