diff options
Diffstat (limited to 'spec/lib/gitlab/alert_management')
3 files changed, 63 insertions, 1 deletions
diff --git a/spec/lib/gitlab/alert_management/alert_params_spec.rb b/spec/lib/gitlab/alert_management/alert_params_spec.rb index 5cf34038f68..284af421f05 100644 --- a/spec/lib/gitlab/alert_management/alert_params_spec.rb +++ b/spec/lib/gitlab/alert_management/alert_params_spec.rb @@ -32,7 +32,8 @@ describe Gitlab::AlertManagement::AlertParams do severity: 'critical', hosts: ['gitlab.com'], payload: payload, - started_at: started_at + started_at: started_at, + fingerprint: nil ) end diff --git a/spec/lib/gitlab/alert_management/alert_status_counts_spec.rb b/spec/lib/gitlab/alert_management/alert_status_counts_spec.rb index 816ed918fe8..728cbf11cda 100644 --- a/spec/lib/gitlab/alert_management/alert_status_counts_spec.rb +++ b/spec/lib/gitlab/alert_management/alert_status_counts_spec.rb @@ -50,6 +50,19 @@ describe Gitlab::AlertManagement::AlertStatusCounts do expect(counts.acknowledged).to eq(0) end end + + context 'when search param is included' do + let(:params) { { search: alert_1.title } } + + it 'returns the correct countss' do + expect(counts.open).to eq(0) + expect(counts.all).to eq(1) + expect(counts.resolved).to eq(1) + expect(counts.ignored).to eq(0) + expect(counts.triggered).to eq(0) + expect(counts.acknowledged).to eq(0) + end + end end end end diff --git a/spec/lib/gitlab/alert_management/fingerprint_spec.rb b/spec/lib/gitlab/alert_management/fingerprint_spec.rb new file mode 100644 index 00000000000..7865d667f71 --- /dev/null +++ b/spec/lib/gitlab/alert_management/fingerprint_spec.rb @@ -0,0 +1,48 @@ +# frozen_string_literal: true + +require 'spec_helper' + +describe Gitlab::AlertManagement::Fingerprint do + using RSpec::Parameterized::TableSyntax + + let_it_be(:alert) { create(:alert_management_alert) } + + describe '.generate' do + subject { described_class.generate(data) } + + context 'when data is an array' do + let(:data) { [1, 'fingerprint', 'given'] } + + it 'flattens the array' do + expect_next_instance_of(described_class) do |obj| + expect(obj).to receive(:flatten_array) + end + + subject + end + + it 'returns the hashed fingerprint' do + expected_fingerprint = Digest::SHA1.hexdigest(data.flatten.map!(&:to_s).join) + expect(subject).to eq(expected_fingerprint) + end + end + + context 'when data is a non-array type' do + where(:data) do + [ + 111, + 'fingerprint', + :fingerprint, + true, + { test: true } + ] + end + + with_them do + it 'performs like a hashed fingerprint' do + expect(subject).to eq(Digest::SHA1.hexdigest(data.to_s)) + end + end + end + end +end |