debian-mirror-gitlab/spec/lib/gitlab/alerting/notification_payload_parser_spec.rb

205 lines
5.5 KiB
Ruby
Raw Normal View History

2020-03-13 15:44:24 +05:30
# frozen_string_literal: true
2020-06-23 00:09:42 +05:30
require 'spec_helper'
2020-03-13 15:44:24 +05:30
2020-07-28 23:09:34 +05:30
RSpec.describe Gitlab::Alerting::NotificationPayloadParser do
let_it_be(:project) { build(:project) }
2020-03-13 15:44:24 +05:30
describe '.call' do
let(:starts_at) { Time.current.change(usec: 0) }
2020-11-24 15:15:51 +05:30
let(:ends_at) { Time.current.change(usec: 0) }
2020-03-13 15:44:24 +05:30
let(:payload) do
{
'title' => 'alert title',
'start_time' => starts_at.rfc3339,
2020-11-24 15:15:51 +05:30
'end_time' => ends_at.rfc3339,
2020-03-13 15:44:24 +05:30
'description' => 'Description',
'monitoring_tool' => 'Monitoring tool name',
'service' => 'Service',
2020-05-24 23:13:21 +05:30
'hosts' => ['gitlab.com'],
'severity' => 'low'
2020-03-13 15:44:24 +05:30
}
end
2020-07-28 23:09:34 +05:30
subject { described_class.call(payload, project) }
2020-03-13 15:44:24 +05:30
it 'returns Prometheus-like payload' do
is_expected.to eq(
{
'annotations' => {
'title' => 'alert title',
'description' => 'Description',
'monitoring_tool' => 'Monitoring tool name',
'service' => 'Service',
2020-05-24 23:13:21 +05:30
'hosts' => ['gitlab.com'],
'severity' => 'low'
2020-03-13 15:44:24 +05:30
},
2020-11-24 15:15:51 +05:30
'startsAt' => starts_at.rfc3339,
'endsAt' => ends_at.rfc3339
2020-03-13 15:44:24 +05:30
}
)
end
context 'when title is blank' do
before do
payload[:title] = ''
end
it 'sets a predefined title' do
expect(subject.dig('annotations', 'title')).to eq('New: Incident')
end
end
context 'when hosts attribute is a string' do
before do
payload[:hosts] = 'gitlab.com'
end
it 'returns hosts as an array of one element' do
expect(subject.dig('annotations', 'hosts')).to eq(['gitlab.com'])
end
end
context 'when the time is in unsupported format' do
before do
payload[:start_time] = 'invalid/date/format'
end
it 'sets startsAt to a current time in RFC3339 format' do
expect(subject['startsAt']).to eq(starts_at.rfc3339)
end
end
context 'when payload is blank' do
let(:payload) { {} }
it 'returns default parameters' do
2020-05-24 23:13:21 +05:30
is_expected.to match(
'annotations' => {
'title' => described_class::DEFAULT_TITLE,
'severity' => described_class::DEFAULT_SEVERITY
},
2020-03-13 15:44:24 +05:30
'startsAt' => starts_at.rfc3339
)
end
2020-05-24 23:13:21 +05:30
context 'when severity is blank' do
before do
payload[:severity] = ''
end
it 'sets severity to the default ' do
expect(subject.dig('annotations', 'severity')).to eq(described_class::DEFAULT_SEVERITY)
end
end
2020-03-13 15:44:24 +05:30
end
2020-06-23 00:09:42 +05:30
context 'with fingerprint' do
before do
payload[:fingerprint] = data
end
shared_examples 'fingerprint generation' do
it 'generates the fingerprint correctly' do
expect(result).to eq(Gitlab::AlertManagement::Fingerprint.generate(data))
end
end
context 'with blank fingerprint' do
it_behaves_like 'fingerprint generation' do
let(:data) { ' ' }
let(:result) { subject.dig('annotations', 'fingerprint') }
end
end
context 'with fingerprint given' do
it_behaves_like 'fingerprint generation' do
let(:data) { 'fingerprint' }
let(:result) { subject.dig('annotations', 'fingerprint') }
end
end
context 'with array fingerprint given' do
it_behaves_like 'fingerprint generation' do
let(:data) { [1, 'fingerprint', 'given'] }
let(:result) { subject.dig('annotations', 'fingerprint') }
end
end
end
2020-11-24 15:15:51 +05:30
context 'with environment' do
let(:environment) { create(:environment, project: project) }
before do
payload[:gitlab_environment_name] = environment.name
end
it 'sets the environment ' do
expect(subject.dig('annotations', 'environment')).to eq(environment)
end
end
2020-03-13 15:44:24 +05:30
context 'when payload attributes have blank lines' do
let(:payload) do
{
'title' => '',
'start_time' => '',
2020-11-24 15:15:51 +05:30
'end_time' => '',
2020-03-13 15:44:24 +05:30
'description' => '',
'monitoring_tool' => '',
'service' => '',
'hosts' => ['']
}
end
it 'returns default parameters' do
is_expected.to eq(
2020-05-24 23:13:21 +05:30
'annotations' => {
'title' => 'New: Incident',
'severity' => described_class::DEFAULT_SEVERITY
},
2020-03-13 15:44:24 +05:30
'startsAt' => starts_at.rfc3339
)
end
end
context 'when payload has secondary params' do
let(:payload) do
{
'description' => 'Description',
'additional' => {
'params' => {
'1' => 'Some value 1',
'2' => 'Some value 2',
'blank' => ''
}
}
}
end
it 'adds secondary params to annotations' do
is_expected.to eq(
'annotations' => {
'title' => 'New: Incident',
2020-05-24 23:13:21 +05:30
'severity' => described_class::DEFAULT_SEVERITY,
2020-03-13 15:44:24 +05:30
'description' => 'Description',
'additional.params.1' => 'Some value 1',
'additional.params.2' => 'Some value 2'
},
'startsAt' => starts_at.rfc3339
)
end
end
context 'when secondary params hash is too big' do
before do
allow(Gitlab::Utils::SafeInlineHash).to receive(:merge_keys!).and_raise(ArgumentError)
end
it 'catches and re-raises an error' do
expect { subject }.to raise_error Gitlab::Alerting::NotificationPayloadParser::BadPayloadError, 'The payload is too big'
end
end
end
end