diff options
Diffstat (limited to 'spec/services/alert_management/process_prometheus_alert_service_spec.rb')
-rw-r--r-- | spec/services/alert_management/process_prometheus_alert_service_spec.rb | 97 |
1 files changed, 71 insertions, 26 deletions
diff --git a/spec/services/alert_management/process_prometheus_alert_service_spec.rb b/spec/services/alert_management/process_prometheus_alert_service_spec.rb index 5b4da5e9077..0ce88f6b5b7 100644 --- a/spec/services/alert_management/process_prometheus_alert_service_spec.rb +++ b/spec/services/alert_management/process_prometheus_alert_service_spec.rb @@ -3,7 +3,7 @@ require 'spec_helper' RSpec.describe AlertManagement::ProcessPrometheusAlertService do - let_it_be(:project) { create(:project) } + let_it_be(:project) { create(:project, :repository) } before do allow(ProjectServiceWorker).to receive(:perform_async) @@ -35,26 +35,31 @@ RSpec.describe AlertManagement::ProcessPrometheusAlertService do } end - context 'when Prometheus alert status is firing' do - let(:status) { 'firing' } + let(:status) { 'firing' } + context 'when Prometheus alert status is firing' do context 'when alert with the same fingerprint already exists' do - let!(:alert) { create(:alert_management_alert, :resolved, project: project, fingerprint: parsed_alert.gitlab_fingerprint) } + let!(:alert) { create(:alert_management_alert, project: project, fingerprint: parsed_alert.gitlab_fingerprint) } + + it_behaves_like 'adds an alert management alert event' + + context 'existing alert is resolved' do + let!(:alert) { create(:alert_management_alert, :resolved, project: project, fingerprint: parsed_alert.gitlab_fingerprint) } - it 'increases alert events count' do - expect { execute }.to change { alert.reload.events }.by(1) + it_behaves_like 'creates an alert management alert' end - context 'when status can be changed' do - it 'changes status to triggered' do - expect { execute }.to change { alert.reload.triggered? }.to(true) - end + context 'existing alert is ignored' do + let!(:alert) { create(:alert_management_alert, :ignored, project: project, fingerprint: parsed_alert.gitlab_fingerprint) } + + it_behaves_like 'adds an alert management alert event' end - it 'does not executes the alert service hooks' do - expect(alert).not_to receive(:execute_services) + context 'two existing alerts, one resolved one open' do + let!(:resolved_alert) { create(:alert_management_alert, :resolved, project: project, fingerprint: parsed_alert.gitlab_fingerprint) } + let!(:alert) { create(:alert_management_alert, project: project, fingerprint: parsed_alert.gitlab_fingerprint) } - subject + it_behaves_like 'adds an alert management alert event' end context 'when status change did not succeed' do @@ -73,23 +78,11 @@ RSpec.describe AlertManagement::ProcessPrometheusAlertService do execute end end - - it { is_expected.to be_success } end context 'when alert does not exist' do context 'when alert can be created' do - it 'creates a new alert' do - expect { execute }.to change { AlertManagement::Alert.where(project: project).count }.by(1) - end - - it 'executes the alert service hooks' do - slack_service = create(:service, type: 'SlackService', project: project, alert_events: true, active: true) - - subject - - expect(ProjectServiceWorker).to have_received(:perform_async).with(slack_service.id, an_instance_of(Hash)) - end + it_behaves_like 'creates an alert management alert' end context 'when alert cannot be created' do @@ -123,6 +116,31 @@ RSpec.describe AlertManagement::ProcessPrometheusAlertService do it 'resolves an existing alert' do expect { execute }.to change { alert.reload.resolved? }.to(true) end + + [true, false].each do |state_tracking_enabled| + context 'existing issue' do + before do + stub_feature_flags(track_resource_state_change_events: state_tracking_enabled) + end + + let!(:alert) { create(:alert_management_alert, :with_issue, project: project, fingerprint: parsed_alert.gitlab_fingerprint) } + + it 'closes the issue' do + issue = alert.issue + + expect { execute } + .to change { issue.reload.state } + .from('opened') + .to('closed') + end + + if state_tracking_enabled + specify { expect { execute }.to change(ResourceStateEvent, :count).by(1) } + else + specify { expect { execute }.to change(Note, :count).by(1) } + end + end + end end context 'when status change did not succeed' do @@ -144,6 +162,33 @@ RSpec.describe AlertManagement::ProcessPrometheusAlertService do it { is_expected.to be_success } end + + context 'environment given' do + let(:environment) { create(:environment, project: project) } + + it 'sets the environment' do + payload['labels']['gitlab_environment_name'] = environment.name + execute + + alert = project.alert_management_alerts.last + + expect(alert.environment).to eq(environment) + end + end + + context 'prometheus alert given' do + let(:prometheus_alert) { create(:prometheus_alert, project: project) } + + it 'sets the prometheus alert and environment' do + payload['labels']['gitlab_alert_id'] = prometheus_alert.prometheus_metric_id + execute + + alert = project.alert_management_alerts.last + + expect(alert.prometheus_alert).to eq(prometheus_alert) + expect(alert.environment).to eq(prometheus_alert.environment) + end + end end context 'when alert payload is invalid' do |