debian-mirror-gitlab/spec/presenters/alert_management/alert_presenter_spec.rb

140 lines
3.9 KiB
Ruby
Raw Normal View History

2020-07-28 23:09:34 +05:30
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe AlertManagement::AlertPresenter do
let_it_be(:project) { create(:project) }
2020-11-24 15:15:51 +05:30
let_it_be(:payload) do
2020-07-28 23:09:34 +05:30
{
'title' => 'Alert title',
'start_time' => '2020-04-27T10:10:22.265949279Z',
2020-11-24 15:15:51 +05:30
'custom' => {
'alert' => {
'fields' => %w[one two]
}
},
'yet' => {
'another' => 73
}
2020-07-28 23:09:34 +05:30
}
end
2020-10-24 23:57:45 +05:30
2020-11-24 15:15:51 +05:30
let_it_be(:alert) { create(:alert_management_alert, project: project, payload: payload) }
2020-10-24 23:57:45 +05:30
let(:alert_url) { "http://localhost/#{project.full_path}/-/alert_management/#{alert.iid}/details" }
2020-07-28 23:09:34 +05:30
subject(:presenter) { described_class.new(alert) }
describe '#issue_description' do
2020-11-24 15:15:51 +05:30
let_it_be(:alert) { create(:alert_management_alert, project: project, payload: {}) }
2020-07-28 23:09:34 +05:30
let(:markdown_line_break) { ' ' }
2020-11-24 15:15:51 +05:30
subject { presenter.issue_description }
2020-07-28 23:09:34 +05:30
2020-11-24 15:15:51 +05:30
context 'with an empty payload' do
it do
is_expected.to eq(
<<~MARKDOWN.chomp
**Start time:** #{presenter.start_time}#{markdown_line_break}
**Severity:** #{presenter.severity}#{markdown_line_break}
**GitLab alert:** #{alert_url}
2020-07-28 23:09:34 +05:30
2020-11-24 15:15:51 +05:30
MARKDOWN
)
end
end
2020-07-28 23:09:34 +05:30
2020-11-24 15:15:51 +05:30
context 'with optional alert attributes' do
let_it_be(:alert) do
create(:alert_management_alert, :with_description, :with_host, :with_service, :with_monitoring_tool, project: project, payload: payload)
end
before do
allow(alert.parsed_payload).to receive(:full_query).and_return('metric > 1')
end
it do
is_expected.to eq(
<<~MARKDOWN.chomp
**Start time:** #{presenter.start_time}#{markdown_line_break}
**Severity:** #{presenter.severity}#{markdown_line_break}
**full_query:** `metric > 1`#{markdown_line_break}
**Service:** #{alert.service}#{markdown_line_break}
**Monitoring tool:** #{alert.monitoring_tool}#{markdown_line_break}
**Hosts:** #{alert.hosts.join(' ')}#{markdown_line_break}
**Description:** #{alert.description}#{markdown_line_break}
**GitLab alert:** #{alert_url}
MARKDOWN
)
end
2020-07-28 23:09:34 +05:30
end
2020-11-24 15:15:51 +05:30
context 'with incident markdown' do
before do
allow(alert.parsed_payload).to receive(:alert_markdown).and_return('**`markdown example`**')
end
it do
is_expected.to eq(
<<~MARKDOWN.chomp
**Start time:** #{presenter.start_time}#{markdown_line_break}
**Severity:** #{presenter.severity}#{markdown_line_break}
**GitLab alert:** #{alert_url}
---
**`markdown example`**
MARKDOWN
)
end
end
context 'with metrics_dashboard_url' do
before do
allow(alert.parsed_payload).to receive(:metrics_dashboard_url).and_return('https://gitlab.com/metrics')
end
it do
is_expected.to eq(
<<~MARKDOWN.chomp
**Start time:** #{presenter.start_time}#{markdown_line_break}
**Severity:** #{presenter.severity}#{markdown_line_break}
**GitLab alert:** #{alert_url}
[](https://gitlab.com/metrics)
MARKDOWN
)
end
2020-07-28 23:09:34 +05:30
end
end
2020-10-24 23:57:45 +05:30
2020-11-24 15:15:51 +05:30
describe '#start_time' do
it 'formats the start time of the alert' do
alert.started_at = Time.utc(2019, 5, 5)
expect(presenter.start_time). to eq('05 May 2019, 12:00AM (UTC)')
2020-10-24 23:57:45 +05:30
end
end
describe '#details_url' do
it 'returns the details URL' do
expect(presenter.details_url).to match(%r{#{project.web_url}/-/alert_management/#{alert.iid}/details})
end
end
2020-11-24 15:15:51 +05:30
describe '#details' do
subject { presenter.details }
it 'renders the payload as inline hash' do
is_expected.to eq(
'title' => 'Alert title',
'start_time' => '2020-04-27T10:10:22.265949279Z',
'custom.alert.fields' => %w[one two],
'yet.another' => 73
)
end
end
2020-07-28 23:09:34 +05:30
end