Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2020-06-29 09:08:55 +0300
committerGitLab Bot <gitlab-bot@gitlab.com>2020-06-29 09:08:55 +0300
commit7bc73460c0262e1686cdf00be4673f10ffabd1a4 (patch)
treede8be15fe8563fb97fe40f2a0157432f4c98e090 /spec/services/alert_management
parentecdd6ffa099d2f3a6a0550e750c1ddd9e4dcc39c (diff)
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/services/alert_management')
-rw-r--r--spec/services/alert_management/process_prometheus_alert_service_spec.rb33
1 files changed, 30 insertions, 3 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..28d390d1518 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,9 +35,9 @@ 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) }
@@ -144,6 +144,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