Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gitlab-ce
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
1
Merge Requests
1
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
gitlab-ce
Commits
9160e428
Commit
9160e428
authored
Jul 08, 2020
by
Sean Arnold
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Tweak & fix alert specs
- Add more cases - Simplify contexts - Fix creating of existing_alert
parent
d61cc087
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
31 additions
and
33 deletions
+31
-33
spec/models/alert_management/alert_spec.rb
spec/models/alert_management/alert_spec.rb
+31
-33
No files found.
spec/models/alert_management/alert_spec.rb
View file @
9160e428
...
@@ -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:
fingerprin
t
)
}
let!
(
:existing_alert
)
{
create
(
:alert_management_alert
,
existing_status
,
fingerprint:
fingerprint
,
project:
projec
t
)
}
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
(
:projec
t
)
}
let
!
(
:existing_alert
)
{
create
(
:alert_management_alert
,
fingerprint:
fingerprin
t
)
}
it
{
is_expected
.
to
be_valid
}
it
{
is_expected
.
to
be_valid
}
end
end
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment