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
cdc0e4d2
Commit
cdc0e4d2
authored
Jul 29, 2020
by
Rémy Coutable
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Reduce test data for service desk issue notifications
Signed-off-by:
Rémy Coutable
<
remy@rymai.me
>
parent
d0ed916b
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
122 additions
and
119 deletions
+122
-119
spec/services/notification_service_spec.rb
spec/services/notification_service_spec.rb
+122
-119
No files found.
spec/services/notification_service_spec.rb
View file @
cdc0e4d2
...
@@ -282,87 +282,6 @@ RSpec.describe NotificationService, :mailer do
...
@@ -282,87 +282,6 @@ RSpec.describe NotificationService, :mailer do
subject
{
notification
.
new_note
(
note
)
}
subject
{
notification
.
new_note
(
note
)
}
before
do
build_team
(
project
)
project
.
add_maintainer
(
issue
.
author
)
project
.
add_maintainer
(
assignee
)
project
.
add_maintainer
(
author
)
@u_custom_off
=
create_user_with_notification
(
:custom
,
'custom_off'
)
project
.
add_guest
(
@u_custom_off
)
create
(
:note_on_issue
,
author:
@u_custom_off
,
noteable:
issue
,
project_id:
issue
.
project_id
,
note:
'i think @subscribed_participant should see this'
)
update_custom_notification
(
:new_note
,
@u_guest_custom
,
resource:
project
)
update_custom_notification
(
:new_note
,
@u_custom_global
)
end
describe
'#new_note'
do
context
do
before
do
add_users
(
project
)
add_user_subscriptions
(
issue
)
reset_delivered_emails!
end
it
'sends emails to recipients'
do
subject
expect_delivery_jobs_count
(
10
)
expect_enqueud_email
(
@u_watcher
.
id
,
note
.
id
,
nil
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
note
.
noteable
.
author
.
id
,
note
.
id
,
nil
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
note
.
noteable
.
assignees
.
first
.
id
,
note
.
id
,
nil
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
@u_custom_global
.
id
,
note
.
id
,
nil
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
@u_mentioned
.
id
,
note
.
id
,
"mentioned"
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
@subscriber
.
id
,
note
.
id
,
"subscribed"
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
@watcher_and_subscriber
.
id
,
note
.
id
,
"subscribed"
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
@subscribed_participant
.
id
,
note
.
id
,
"subscribed"
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
@u_custom_off
.
id
,
note
.
id
,
nil
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
@unsubscribed_mentioned
.
id
,
note
.
id
,
"mentioned"
,
mail:
"note_issue_email"
)
end
it
"emails the note author if they've opted into notifications about their activity"
,
:deliver_mails_inline
do
note
.
author
.
notified_of_own_activity
=
true
notification
.
new_note
(
note
)
should_email
(
note
.
author
)
expect
(
find_email_for
(
note
.
author
)).
to
have_header
(
'X-GitLab-NotificationReason'
,
'own_activity'
)
end
it_behaves_like
'project emails are disabled'
,
check_delivery_jobs_queue:
true
do
let
(
:notification_target
)
{
note
}
let
(
:notification_trigger
)
{
notification
.
new_note
(
note
)
}
end
end
it
'filters out "mentioned in" notes'
do
mentioned_note
=
SystemNoteService
.
cross_reference
(
mentioned_issue
,
issue
,
issue
.
author
)
reset_delivered_emails!
notification
.
new_note
(
mentioned_note
)
expect_no_delivery_jobs
end
context
'participating'
do
context
'by note'
do
before
do
note
.
author
=
@u_lazy_participant
note
.
save
end
it
{
expect
{
subject
}.
not_to
have_enqueued_email
(
@u_lazy_participant
.
id
,
note
.
id
,
mail:
"note_issue_email"
)
}
end
end
end
context
'on service desk issue'
do
context
'on service desk issue'
do
before
do
before
do
allow
(
Notify
).
to
receive
(
:service_desk_new_note_email
)
allow
(
Notify
).
to
receive
(
:service_desk_new_note_email
)
...
@@ -436,64 +355,148 @@ RSpec.describe NotificationService, :mailer do
...
@@ -436,64 +355,148 @@ RSpec.describe NotificationService, :mailer do
end
end
end
end
describe
'
new note on issue in project that belongs to a group
'
do
describe
'
#new_note
'
do
before
do
before
do
note
.
project
.
namespace_id
=
group
.
id
build_team
(
project
)
group
.
add_user
(
@u_watcher
,
GroupMember
::
MAINTAINER
)
project
.
add_maintainer
(
issue
.
author
)
group
.
add_user
(
@u_custom_global
,
GroupMember
::
MAINTAINER
)
project
.
add_maintainer
(
assignee
)
note
.
project
.
save
project
.
add_maintainer
(
author
)
@u_custom_off
=
create_user_with_notification
(
:custom
,
'custom_off'
)
project
.
add_guest
(
@u_custom_off
)
create
(
:note_on_issue
,
author:
@u_custom_off
,
noteable:
issue
,
project_id:
issue
.
project_id
,
note:
'i think @subscribed_participant should see this'
)
@u_watcher
.
notification_settings_for
(
note
.
project
).
participating!
update_custom_notification
(
:new_note
,
@u_guest_custom
,
resource:
project
)
@u_watcher
.
notification_settings_for
(
group
).
global!
update_custom_notification
(
:new_note
,
@u_custom_global
)
update_custom_notification
(
:new_note
,
@u_custom_global
)
reset_delivered_emails!
end
end
shared_examples
'new note notifications'
do
context
'with users'
do
it
'sends notifications'
,
:deliver_mails_inline
do
before
do
add_users
(
project
)
add_user_subscriptions
(
issue
)
reset_delivered_emails!
end
it
'sends emails to recipients'
do
subject
expect_delivery_jobs_count
(
10
)
expect_enqueud_email
(
@u_watcher
.
id
,
note
.
id
,
nil
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
note
.
noteable
.
author
.
id
,
note
.
id
,
nil
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
note
.
noteable
.
assignees
.
first
.
id
,
note
.
id
,
nil
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
@u_custom_global
.
id
,
note
.
id
,
nil
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
@u_mentioned
.
id
,
note
.
id
,
"mentioned"
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
@subscriber
.
id
,
note
.
id
,
"subscribed"
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
@watcher_and_subscriber
.
id
,
note
.
id
,
"subscribed"
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
@subscribed_participant
.
id
,
note
.
id
,
"subscribed"
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
@u_custom_off
.
id
,
note
.
id
,
nil
,
mail:
"note_issue_email"
)
expect_enqueud_email
(
@unsubscribed_mentioned
.
id
,
note
.
id
,
"mentioned"
,
mail:
"note_issue_email"
)
end
it
"emails the note author if they've opted into notifications about their activity"
,
:deliver_mails_inline
do
note
.
author
.
notified_of_own_activity
=
true
notification
.
new_note
(
note
)
notification
.
new_note
(
note
)
should_email
(
note
.
noteable
.
author
)
should_email
(
note
.
author
)
should_email
(
note
.
noteable
.
assignees
.
first
)
expect
(
find_email_for
(
note
.
author
)).
to
have_header
(
'X-GitLab-NotificationReason'
,
'own_activity'
)
should_email
(
@u_mentioned
)
end
should_email
(
@u_custom_global
)
should_not_email
(
@u_guest_custom
)
should_not_email
(
@u_guest_watcher
)
should_not_email
(
@u_watcher
)
should_not_email
(
note
.
author
)
should_not_email
(
@u_participating
)
should_not_email
(
@u_disabled
)
should_not_email
(
@u_lazy_participant
)
expect
(
find_email_for
(
@u_mentioned
)).
to
have_header
(
'X-GitLab-NotificationReason'
,
'mentioned'
)
it_behaves_like
'project emails are disabled'
,
check_delivery_jobs_queue:
true
do
expect
(
find_email_for
(
@u_custom_global
)).
to
have_header
(
'X-GitLab-NotificationReason'
,
''
)
let
(
:notification_target
)
{
note
}
let
(
:notification_trigger
)
{
notification
.
new_note
(
note
)
}
end
end
end
end
let
(
:group
)
{
create
(
:group
)
}
it
'filters out "mentioned in" notes'
do
mentioned_note
=
SystemNoteService
.
cross_reference
(
mentioned_issue
,
issue
,
issue
.
author
)
reset_delivered_emails!
it_behaves_like
'new note notifications'
notification
.
new_note
(
mentioned_note
)
it_behaves_like
'project emails are disabled'
,
check_delivery_jobs_queue:
true
do
expect_no_delivery_jobs
let
(
:notification_target
)
{
note
}
let
(
:notification_trigger
)
{
notification
.
new_note
(
note
)
}
end
end
context
'which is a subgroup'
do
context
'participating'
do
let!
(
:parent
)
{
create
(
:group
)
}
context
'by note'
do
let!
(
:group
)
{
create
(
:group
,
parent:
parent
)
}
before
do
note
.
author
=
@u_lazy_participant
note
.
save
end
it
{
expect
{
subject
}.
not_to
have_enqueued_email
(
@u_lazy_participant
.
id
,
note
.
id
,
mail:
"note_issue_email"
)
}
end
end
it_behaves_like
'new note notifications'
context
'in project that belongs to a group'
do
let_it_be
(
:parent_group
)
{
create
(
:group
)
}
it
'overrides child objects with global level'
do
before
do
user
=
create
(
:user
)
note
.
project
.
namespace_id
=
group
.
id
parent
.
add_developer
(
user
)
group
.
add_user
(
@u_watcher
,
GroupMember
::
MAINTAINER
)
user
.
notification_settings_for
(
parent
).
watch!
group
.
add_user
(
@u_custom_global
,
GroupMember
::
MAINTAINER
)
note
.
project
.
save
@u_watcher
.
notification_settings_for
(
note
.
project
).
participating!
@u_watcher
.
notification_settings_for
(
group
).
global!
update_custom_notification
(
:new_note
,
@u_custom_global
)
reset_delivered_emails!
reset_delivered_emails!
end
notification
.
new_note
(
note
)
shared_examples
'new note notifications'
do
it
'sends notifications'
,
:deliver_mails_inline
do
notification
.
new_note
(
note
)
should_email
(
note
.
noteable
.
author
)
should_email
(
note
.
noteable
.
assignees
.
first
)
should_email
(
@u_mentioned
)
should_email
(
@u_custom_global
)
should_not_email
(
@u_guest_custom
)
should_not_email
(
@u_guest_watcher
)
should_not_email
(
@u_watcher
)
should_not_email
(
note
.
author
)
should_not_email
(
@u_participating
)
should_not_email
(
@u_disabled
)
should_not_email
(
@u_lazy_participant
)
expect
(
find_email_for
(
@u_mentioned
)).
to
have_header
(
'X-GitLab-NotificationReason'
,
'mentioned'
)
expect
(
find_email_for
(
@u_custom_global
)).
to
have_header
(
'X-GitLab-NotificationReason'
,
''
)
end
end
context
'which is a top-level group'
do
let!
(
:group
)
{
parent_group
}
expect_enqueud_email
(
user
.
id
,
note
.
id
,
nil
,
mail:
"note_issue_email"
)
it_behaves_like
'new note notifications'
it_behaves_like
'project emails are disabled'
,
check_delivery_jobs_queue:
true
do
let
(
:notification_target
)
{
note
}
let
(
:notification_trigger
)
{
notification
.
new_note
(
note
)
}
end
end
context
'which is a subgroup'
do
let!
(
:group
)
{
create
(
:group
,
parent:
parent_group
)
}
it_behaves_like
'new note notifications'
it
'overrides child objects with global level'
do
user
=
create
(
:user
)
parent_group
.
add_developer
(
user
)
user
.
notification_settings_for
(
parent_group
).
watch!
reset_delivered_emails!
notification
.
new_note
(
note
)
expect_enqueud_email
(
user
.
id
,
note
.
id
,
nil
,
mail:
"note_issue_email"
)
end
end
end
end
end
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