45 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Ruby
		
	
	
	
			
		
		
	
	
			45 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Ruby
		
	
	
	
# frozen_string_literal: true
 | 
						|
 | 
						|
require 'spec_helper'
 | 
						|
 | 
						|
RSpec.describe Gitlab::SidekiqLogging::ExceptionHandler do
 | 
						|
  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',
 | 
						|
        error_backtrace: Rails.backtrace_cleaner.clean(backtrace)
 | 
						|
      )
 | 
						|
 | 
						|
      expect(logger).to receive(:warn).with(expected_data)
 | 
						|
 | 
						|
      subject
 | 
						|
    end
 | 
						|
  end
 | 
						|
end
 |