Commit 9160e428 authored by Sean Arnold's avatar Sean Arnold

Tweak & fix alert specs

- Add more cases
- Simplify contexts
- Fix creating of existing_alert
parent d61cc087
...@@ -83,52 +83,50 @@ RSpec.describe AlertManagement::Alert do ...@@ -83,52 +83,50 @@ RSpec.describe AlertManagement::Alert do
end end
describe 'fingerprint' do describe 'fingerprint' do
let_it_be(:project) { create(:project) }
let_it_be(:fingerprint) { 'fingerprint' } let_it_be(:fingerprint) { 'fingerprint' }
let_it_be(:existing_alert) { create(:alert_management_alert, fingerprint: fingerprint) }
let(:new_alert) { build(:alert_management_alert, fingerprint: fingerprint, project: project) } let(:new_alert) { build(:alert_management_alert, fingerprint: fingerprint, project: project) }
subject { new_alert } subject { new_alert }
context 'adding an alert with the same fingerprint' do context 'adding an alert with the same fingerprint' do
context 'same project' do context 'same project, various states' do
let(:project) { existing_alert.project } using RSpec::Parameterized::TableSyntax
it { is_expected.not_to be_valid } # We are only validating uniqueness for non-resolved alerts
where(:existing_status, :new_status, :valid) do
context 'various states' do :resolved | :triggered | true
using RSpec::Parameterized::TableSyntax :resolved | :acknowledged | true
:resolved | :ignored | true
# We are only validating uniqueness for non-resolved alerts :resolved | :resolved | true
where(:existing_status, :new_status, :valid) do :triggered | :triggered | false
:resolved | :triggered | true :triggered | :acknowledged | false
:resolved | :resolved | true :triggered | :ignored | false
:triggered | :triggered | false :triggered | :resolved | true
:triggered | :acknowledged | false :acknowledged | :triggered | false
:triggered | :ignored | false :acknowledged | :acknowledged | false
:triggered | :resolved | true :acknowledged | :ignored | false
:acknowledged | :triggered | false :acknowledged | :resolved | true
:acknowledged | :acknowledged | false :ignored | :triggered | false
:acknowledged | :ignored | false :ignored | :acknowledged | false
:acknowledged | :resolved | true :ignored | :ignored | false
:ignored | :triggered | false :ignored | :resolved | true
:ignored | :acknowledged | false end
:ignored | :ignored | false
:ignored | :resolved | true
end
with_them do with_them do
let(:existing_alert) { create(:alert_management_alert, existing_status, fingerprint: fingerprint) } let!(:existing_alert) { create(:alert_management_alert, existing_status, fingerprint: fingerprint, project: project) }
let(:new_alert) { build(:alert_management_alert, new_status, fingerprint: fingerprint, project: project) } let(:new_alert) { build(:alert_management_alert, new_status, fingerprint: fingerprint, project: project) }
it 'gives the correct validity' do if params[:valid]
expect(new_alert.valid?).to eq(valid) it { is_expected.to be_valid }
end else
it { is_expected.to be_invalid }
end end
end end
end end
context 'different project' do context 'different project' do
let(:project) { create(:project) } let!(:existing_alert) { create(:alert_management_alert, fingerprint: fingerprint) }
it { is_expected.to be_valid } it { is_expected.to be_valid }
end end
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment