debian-mirror-gitlab/spec/services/incident_management/incidents/create_service_spec.rb
2023-03-04 22:38:38 +05:30

123 lines
3.9 KiB
Ruby

# 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 }
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! }
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
it 'created issue has correct attributes', :aggregate_failures do
create_incident
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 }
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
end
end
context 'with an alert' do
subject(:create_incident) { described_class.new(project, user, title: title, description: description, alert: alert).execute }
context 'when the alert is valid' do
let(:alert) { create(:alert_management_alert, project: project) }
it 'associates the alert with the incident' do
expect(create_incident[:issue].reload.alert_management_alerts).to match_array([alert])
end
end
context 'when the alert is not valid' do
let(:alert) { create(:alert_management_alert, :with_validation_errors, project: project) }
it 'does not associate the alert with the incident' do
expect(create_incident[:issue].reload.alert_management_alerts).to be_empty
end
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.errors).to contain_exactly("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
context 'with alert' do
let(:alert) { create(:alert_management_alert, project: project) }
subject(:create_incident) { described_class.new(project, user, title: title, description: description, alert: alert).execute }
context 'the alert prevents the issue from saving' do
let(:alert) { create(:alert_management_alert, :with_validation_errors, project: project) }
it 'responds with errors' do
expect(create_incident).to be_error
expect(create_incident.errors).to contain_exactly('Hosts hosts array is over 255 chars')
end
end
end
end
end
end