blob: 74b6df241781d446ac90450c268c3c49bd757d69 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Gitlab::ErrorTracking::Processor::SanitizeErrorMessageProcessor, :sentry do
describe '.call' do
let(:exception) { StandardError.new('raw error') }
let(:result_hash) { described_class.call(event).to_hash }
shared_examples 'processes the exception' do
it 'cleans the exception message' do
expect(Gitlab::Sanitizers::ExceptionMessage).to receive(:clean).with(
'StandardError', match('raw error')
).and_return('cleaned')
expect(result_hash[:exception][:values].first).to include(
type: 'StandardError',
value: 'cleaned'
)
end
end
context 'with Raven event' do
let(:raven_required_options) do
{
configuration: Raven.configuration,
context: Raven.context,
breadcrumbs: Raven.breadcrumbs
}
end
let(:event) { Raven::Event.from_exception(exception, raven_required_options) }
it_behaves_like 'processes the exception'
end
context 'with Sentry event' do
let(:event) { Sentry.get_current_client.event_from_exception(exception) }
it_behaves_like 'processes the exception'
end
context 'with invalid event' do
let(:event) { instance_double('Sentry::Event', to_hash: { invalid: true }) }
it 'does nothing' do
extracted_exception = instance_double('Sentry::SingleExceptionInterface', value: nil)
allow(described_class).to receive(:extract_exceptions_from).and_return([extracted_exception])
expect(Gitlab::Sanitizers::ExceptionMessage).not_to receive(:clean)
expect(result_hash).to eq(invalid: true)
end
end
end
end
|