Commit e90c1b4a authored by Vitali Tatarintev's avatar Vitali Tatarintev

Extract AlertPresenter from CreateAlertIssue

Extract presentation logic from `CreateAlertIssueService`
parent e1c83c24
...@@ -10,6 +10,7 @@ module AlertManagement ...@@ -10,6 +10,7 @@ module AlertManagement
include Sortable include Sortable
include Noteable include Noteable
include Gitlab::SQL::Pattern include Gitlab::SQL::Pattern
include Presentable
STATUSES = { STATUSES = {
triggered: 0, triggered: 0,
......
# frozen_string_literal: true
module AlertManagement
class AlertPresenter < Gitlab::View::Presenter::Delegated
include Gitlab::Utils::StrongMemoize
include IncidentManagement::Settings
def initialize(alert, _attributes = {})
super
@alert = alert
@project = alert.project
end
delegate :alert_markdown, :issue_summary_markdown, to: :alerting_alert
def issue_description
horizontal_line = "\n\n---\n\n"
[
issue_summary_markdown,
alert_markdown,
incident_management_setting.issue_template_content
].compact.join(horizontal_line)
end
private
attr_reader :alert, :project
def alert_payload
if alert.prometheus?
alert.payload
else
Gitlab::Alerting::NotificationPayloadParser.call(alert.payload.to_h)
end
end
def alerting_alert
strong_memoize(:alertign_alert) do
Gitlab::Alerting::Alert.new(project: project, payload: alert_payload).present
end
end
end
end
...@@ -17,7 +17,7 @@ module AlertManagement ...@@ -17,7 +17,7 @@ module AlertManagement
return error_no_permissions unless allowed? return error_no_permissions unless allowed?
return error_issue_already_exists if alert.issue return error_issue_already_exists if alert.issue
result = create_issue(user, alert_payload) result = create_issue
@issue = result.payload[:issue] @issue = result.payload[:issue]
return error(result.message) if result.error? return error(result.message) if result.error?
...@@ -36,7 +36,7 @@ module AlertManagement ...@@ -36,7 +36,7 @@ module AlertManagement
user.can?(:create_issue, project) user.can?(:create_issue, project)
end end
def create_issue(user, alert_payload) def create_issue
issue = do_create_issue(label_ids: issue_label_ids) issue = do_create_issue(label_ids: issue_label_ids)
# Create an unlabelled issue if we couldn't create the issue # Create an unlabelled issue if we couldn't create the issue
...@@ -53,14 +53,6 @@ module AlertManagement ...@@ -53,14 +53,6 @@ module AlertManagement
success success
end end
def alert_payload
if alert.prometheus?
alert.payload
else
Gitlab::Alerting::NotificationPayloadParser.call(alert.payload.to_h)
end
end
def update_alert_issue_id def update_alert_issue_id
alert.update(issue_id: issue.id) alert.update(issue_id: issue.id)
end end
...@@ -85,24 +77,16 @@ module AlertManagement ...@@ -85,24 +77,16 @@ module AlertManagement
Issues::CreateService.new( Issues::CreateService.new(
project, project,
user, user,
title: issue_title, title: alert_presenter.title,
description: issue_description, description: alert_presenter.issue_description,
**params **params
).execute ).execute
end end
def issue_title def alert_presenter
alert_presenter.full_title strong_memoize(:alert_presenter) do
end alert.present
end
def issue_description
horizontal_line = "\n\n---\n\n"
[
alert_summary,
alert_markdown,
issue_template_content
].compact.join(horizontal_line)
end end
def issue_label_ids def issue_label_ids
...@@ -117,31 +101,6 @@ module AlertManagement ...@@ -117,31 +101,6 @@ module AlertManagement
.execute .execute
end end
def alert_summary
alert_presenter.issue_summary_markdown
end
def alert_markdown
alert_presenter.alert_markdown
end
def alert_presenter
strong_memoize(:alert_presenter) do
Gitlab::Alerting::Alert.new(project: project, payload: alert_payload).present
end
end
def issue_template_content
incident_management_setting.issue_template_content
end
def incident_management_setting
strong_memoize(:incident_management_setting) do
project.incident_management_setting ||
project.build_incident_management_setting
end
end
def issue_errors(issue) def issue_errors(issue)
issue.errors.full_messages.to_sentence issue.errors.full_messages.to_sentence
end end
......
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe AlertManagement::AlertPresenter do
let_it_be(:project) { create(:project) }
let_it_be(:generic_payload) do
{
'title' => 'Alert title',
'start_time' => '2020-04-27T10:10:22.265949279Z',
'custom' => { 'param' => 73 }
}
end
let_it_be(:generic_alert) do
create(:alert_management_alert, project: project, payload: generic_payload)
end
let_it_be(:prometheus_payload) do
{
'annotations' => {
'title' => 'Alert title',
'gitlab_incident_markdown' => '**`markdown example`**'
},
'startsAt' => '2020-04-27T10:10:22.265949279Z',
'generatorURL' => 'http://8d467bd4607a:9090/graph?g0.expr=vector%281%29&g0.tab=1'
}
end
let_it_be(:prometheus_alert) do
create(:alert_management_alert, :prometheus, project: project, payload: prometheus_payload)
end
let(:alert) { generic_alert }
let(:presenter) { described_class.new(alert) }
describe '#issue_description' do
let(:markdown_line_break) { ' ' }
context 'with generic alert' do
let(:alert) { generic_alert }
let(:parsed_payload) { Gitlab::Alerting::NotificationPayloadParser.call(generic_payload.to_h) }
let(:alert_presenter) { Gitlab::Alerting::Alert.new(project: project, payload: parsed_payload).present }
it 'returns an alert issue description' do
expect(presenter.issue_description).to eq(
<<~MARKDOWN.chomp
#### Summary
**Start time:** #{alert_presenter.start_time}
#### Alert Details
**custom.param:** 73#{markdown_line_break}
**severity:** critical
MARKDOWN
)
end
end
context 'with prometheus alert' do
let(:alert) { prometheus_alert }
let(:alert_presenter) { Gitlab::Alerting::Alert.new(project: project, payload: prometheus_payload).present }
it 'returns an alert issue description' do
expect(presenter.issue_description).to eq(
<<~MARKDOWN.chomp
#### Summary
**Start time:** #{alert_presenter.start_time}#{markdown_line_break}
**full_query:** `vector(1)`
---
**`markdown example`**
MARKDOWN
)
end
end
end
end
...@@ -8,10 +8,6 @@ RSpec.describe AlertManagement::CreateAlertIssueService do ...@@ -8,10 +8,6 @@ RSpec.describe AlertManagement::CreateAlertIssueService do
let_it_be(:project) { create(:project, group: group) } let_it_be(:project) { create(:project, group: group) }
let_it_be(:payload) do let_it_be(:payload) do
{ {
'title' => 'Alert title',
'annotations' => {
'title' => 'Alert title'
},
'startsAt' => '2020-04-27T10:10:22.265949279Z', 'startsAt' => '2020-04-27T10:10:22.265949279Z',
'generatorURL' => 'http://8d467bd4607a:9090/graph?g0.expr=vector%281%29&g0.tab=1' 'generatorURL' => 'http://8d467bd4607a:9090/graph?g0.expr=vector%281%29&g0.tab=1'
} }
...@@ -61,7 +57,7 @@ RSpec.describe AlertManagement::CreateAlertIssueService do ...@@ -61,7 +57,7 @@ RSpec.describe AlertManagement::CreateAlertIssueService do
end end
it 'sets the issue title' do it 'sets the issue title' do
expect(created_issue.title).to eq(alert_presenter.title) expect(created_issue.title).to eq(alert.title)
end end
it 'sets the issue description' do it 'sets the issue description' do
...@@ -187,11 +183,11 @@ RSpec.describe AlertManagement::CreateAlertIssueService do ...@@ -187,11 +183,11 @@ RSpec.describe AlertManagement::CreateAlertIssueService do
end end
context 'when issue cannot be created' do context 'when issue cannot be created' do
let(:alert) { prometheus_alert } let(:alert) { generic_alert }
before do before do
# set invalid payload for Prometheus alert # Invalid alert
alert.update!(payload: {}) alert.update_columns(title: '')
end end
it 'has an unsuccessful status' do it 'has an unsuccessful status' do
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment