2020-10-24 23:57:45 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
require 'spec_helper'
|
|
|
|
|
|
|
|
RSpec.describe IncidentManagement::Incidents::CreateService do
|
|
|
|
let_it_be(:project) { create(:project) }
|
|
|
|
let_it_be(:user) { User.alert_bot }
|
2021-09-30 23:02:18 +05:30
|
|
|
|
2020-10-24 23:57:45 +05:30
|
|
|
let(:description) { 'Incident description' }
|
|
|
|
|
|
|
|
describe '#execute' do
|
|
|
|
subject(:create_incident) { described_class.new(project, user, title: title, description: description).execute }
|
|
|
|
|
|
|
|
context 'when incident has title and description' do
|
|
|
|
let(:title) { 'Incident title' }
|
|
|
|
let(:new_issue) { Issue.last! }
|
2020-11-24 15:15:51 +05:30
|
|
|
let(:label_title) { attributes_for(:label, :incident)[:title] }
|
2020-10-24 23:57:45 +05:30
|
|
|
|
|
|
|
it 'responds with success' do
|
|
|
|
expect(create_incident).to be_success
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'creates an incident issue' do
|
|
|
|
expect { create_incident }.to change(Issue, :count).by(1)
|
|
|
|
end
|
|
|
|
|
2020-11-24 15:15:51 +05:30
|
|
|
it 'created issue has correct attributes', :aggregate_failures do
|
2020-10-24 23:57:45 +05:30
|
|
|
create_incident
|
2020-11-24 15:15:51 +05:30
|
|
|
|
|
|
|
expect(new_issue.title).to eq(title)
|
|
|
|
expect(new_issue.description).to eq(description)
|
|
|
|
expect(new_issue.author).to eq(user)
|
|
|
|
end
|
|
|
|
|
|
|
|
it_behaves_like 'incident issue' do
|
|
|
|
before do
|
|
|
|
create_incident
|
|
|
|
end
|
|
|
|
|
|
|
|
let(:issue) { new_issue }
|
2021-02-22 17:27:13 +05:30
|
|
|
|
2022-03-02 08:16:31 +05:30
|
|
|
include_examples 'does not have incident label'
|
2020-11-24 15:15:51 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
context 'with default severity' do
|
|
|
|
it 'sets the correct severity level to "unknown"' do
|
|
|
|
create_incident
|
|
|
|
expect(new_issue.severity).to eq(IssuableSeverity::DEFAULT)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'with severity' do
|
|
|
|
using RSpec::Parameterized::TableSyntax
|
|
|
|
|
|
|
|
subject(:create_incident) { described_class.new(project, user, title: title, description: description, severity: severity).execute }
|
|
|
|
|
|
|
|
where(:severity, :incident_severity) do
|
|
|
|
'critical' | 'critical'
|
|
|
|
'high' | 'high'
|
|
|
|
'medium' | 'medium'
|
|
|
|
'low' | 'low'
|
|
|
|
'unknown' | 'unknown'
|
|
|
|
end
|
|
|
|
|
|
|
|
with_them do
|
|
|
|
it 'sets the correct severity level' do
|
|
|
|
create_incident
|
|
|
|
expect(new_issue.severity).to eq(incident_severity)
|
|
|
|
end
|
2020-10-24 23:57:45 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when incident label does not exists' do
|
2022-03-02 08:16:31 +05:30
|
|
|
it 'does not create incident label' do
|
|
|
|
expect { create_incident }.to not_change { project.labels.where(title: label_title).count }
|
2020-10-24 23:57:45 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when incident label already exists' do
|
|
|
|
let!(:label) { create(:label, project: project, title: label_title) }
|
|
|
|
|
|
|
|
it 'does not create new labels' do
|
|
|
|
expect { create_incident }.not_to change(Label, :count)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
context 'when incident has no title' do
|
|
|
|
let(:title) { '' }
|
|
|
|
|
|
|
|
it 'does not create an issue' do
|
|
|
|
expect { create_incident }.not_to change(Issue, :count)
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'responds with errors' do
|
|
|
|
expect(create_incident).to be_error
|
|
|
|
expect(create_incident.message).to eq("Title can't be blank")
|
|
|
|
end
|
|
|
|
|
|
|
|
it 'result payload contains an Issue object' do
|
|
|
|
expect(create_incident.payload[:issue]).to be_kind_of(Issue)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|