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
2ac20bc7
Commit
2ac20bc7
authored
Oct 30, 2018
by
Chantal Rollison
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Port of ccr/51520_change_milestone_email to EE
parent
32655ecc
Changes
21
Hide whitespace changes
Inline
Side-by-side
Showing
21 changed files
with
399 additions
and
7 deletions
+399
-7
app/mailers/emails/issues.rb
app/mailers/emails/issues.rb
+14
-0
app/mailers/emails/merge_requests.rb
app/mailers/emails/merge_requests.rb
+14
-0
app/mailers/previews/notify_preview.rb
app/mailers/previews/notify_preview.rb
+20
-0
app/services/issuable_base_service.rb
app/services/issuable_base_service.rb
+8
-0
app/services/issues/update_service.rb
app/services/issues/update_service.rb
+14
-0
app/services/merge_requests/update_service.rb
app/services/merge_requests/update_service.rb
+14
-0
app/services/milestones/destroy_service.rb
app/services/milestones/destroy_service.rb
+1
-1
app/services/notification_service.rb
app/services/notification_service.rb
+40
-3
app/views/notify/changed_milestone_issue_email.html.haml
app/views/notify/changed_milestone_issue_email.html.haml
+3
-0
app/views/notify/changed_milestone_issue_email.text.erb
app/views/notify/changed_milestone_issue_email.text.erb
+1
-0
app/views/notify/changed_milestone_merge_request_email.html.haml
...ws/notify/changed_milestone_merge_request_email.html.haml
+3
-0
app/views/notify/changed_milestone_merge_request_email.text.erb
...ews/notify/changed_milestone_merge_request_email.text.erb
+1
-0
app/views/notify/removed_milestone_issue_email.html.haml
app/views/notify/removed_milestone_issue_email.html.haml
+2
-0
app/views/notify/removed_milestone_issue_email.text.erb
app/views/notify/removed_milestone_issue_email.text.erb
+1
-0
app/views/notify/removed_milestone_merge_request_email.html.haml
...ws/notify/removed_milestone_merge_request_email.html.haml
+2
-0
app/views/notify/removed_milestone_merge_request_email.text.erb
...ews/notify/removed_milestone_merge_request_email.text.erb
+1
-0
changelogs/unreleased/ccr-51520_change_milestone_email.yml
changelogs/unreleased/ccr-51520_change_milestone_email.yml
+5
-0
doc/workflow/notifications.md
doc/workflow/notifications.md
+4
-0
spec/services/issues/update_service_spec.rb
spec/services/issues/update_service_spec.rb
+46
-2
spec/services/merge_requests/update_service_spec.rb
spec/services/merge_requests/update_service_spec.rb
+45
-1
spec/services/notification_service_spec.rb
spec/services/notification_service_spec.rb
+160
-0
No files found.
app/mailers/emails/issues.rb
View file @
2ac20bc7
...
@@ -45,6 +45,20 @@ module Emails
...
@@ -45,6 +45,20 @@ module Emails
mail_answer_thread
(
@issue
,
issue_thread_options
(
updated_by_user_id
,
recipient_id
,
reason
))
mail_answer_thread
(
@issue
,
issue_thread_options
(
updated_by_user_id
,
recipient_id
,
reason
))
end
end
def
removed_milestone_issue_email
(
recipient_id
,
issue_id
,
updated_by_user_id
,
reason
=
nil
)
setup_issue_mail
(
issue_id
,
recipient_id
)
mail_answer_thread
(
@issue
,
issue_thread_options
(
updated_by_user_id
,
recipient_id
,
reason
))
end
def
changed_milestone_issue_email
(
recipient_id
,
issue_id
,
milestone
,
updated_by_user_id
,
reason
=
nil
)
setup_issue_mail
(
issue_id
,
recipient_id
)
@milestone
=
milestone
@milestone_url
=
milestone_url
(
@milestone
)
mail_answer_thread
(
@issue
,
issue_thread_options
(
updated_by_user_id
,
recipient_id
,
reason
))
end
def
issue_status_changed_email
(
recipient_id
,
issue_id
,
status
,
updated_by_user_id
,
reason
=
nil
)
def
issue_status_changed_email
(
recipient_id
,
issue_id
,
status
,
updated_by_user_id
,
reason
=
nil
)
setup_issue_mail
(
issue_id
,
recipient_id
)
setup_issue_mail
(
issue_id
,
recipient_id
)
...
...
app/mailers/emails/merge_requests.rb
View file @
2ac20bc7
...
@@ -42,6 +42,20 @@ module Emails
...
@@ -42,6 +42,20 @@ module Emails
mail_answer_thread
(
@merge_request
,
merge_request_thread_options
(
updated_by_user_id
,
recipient_id
,
reason
))
mail_answer_thread
(
@merge_request
,
merge_request_thread_options
(
updated_by_user_id
,
recipient_id
,
reason
))
end
end
def
removed_milestone_merge_request_email
(
recipient_id
,
merge_request_id
,
updated_by_user_id
,
reason
=
nil
)
setup_merge_request_mail
(
merge_request_id
,
recipient_id
)
mail_answer_thread
(
@merge_request
,
merge_request_thread_options
(
updated_by_user_id
,
recipient_id
,
reason
))
end
def
changed_milestone_merge_request_email
(
recipient_id
,
merge_request_id
,
milestone
,
updated_by_user_id
,
reason
=
nil
)
setup_merge_request_mail
(
merge_request_id
,
recipient_id
)
@milestone
=
milestone
@milestone_url
=
milestone_url
(
@milestone
)
mail_answer_thread
(
@merge_request
,
merge_request_thread_options
(
updated_by_user_id
,
recipient_id
,
reason
))
end
def
closed_merge_request_email
(
recipient_id
,
merge_request_id
,
updated_by_user_id
,
reason
=
nil
)
def
closed_merge_request_email
(
recipient_id
,
merge_request_id
,
updated_by_user_id
,
reason
=
nil
)
setup_merge_request_mail
(
merge_request_id
,
recipient_id
)
setup_merge_request_mail
(
merge_request_id
,
recipient_id
)
...
...
app/mailers/previews/notify_preview.rb
View file @
2ac20bc7
...
@@ -70,6 +70,14 @@ class NotifyPreview < ActionMailer::Preview
...
@@ -70,6 +70,14 @@ class NotifyPreview < ActionMailer::Preview
Notify
.
issue_status_changed_email
(
user
.
id
,
issue
.
id
,
'closed'
,
user
.
id
).
message
Notify
.
issue_status_changed_email
(
user
.
id
,
issue
.
id
,
'closed'
,
user
.
id
).
message
end
end
def
removed_milestone_issue_email
Notify
.
removed_milestone_issue_email
(
user
.
id
,
issue
.
id
,
user
.
id
)
end
def
changed_milestone_issue_email
Notify
.
changed_milestone_issue_email
(
user
.
id
,
issue
.
id
,
milestone
,
user
.
id
)
end
def
closed_merge_request_email
def
closed_merge_request_email
Notify
.
closed_merge_request_email
(
user
.
id
,
issue
.
id
,
user
.
id
).
message
Notify
.
closed_merge_request_email
(
user
.
id
,
issue
.
id
,
user
.
id
).
message
end
end
...
@@ -82,6 +90,14 @@ class NotifyPreview < ActionMailer::Preview
...
@@ -82,6 +90,14 @@ class NotifyPreview < ActionMailer::Preview
Notify
.
merged_merge_request_email
(
user
.
id
,
merge_request
.
id
,
user
.
id
).
message
Notify
.
merged_merge_request_email
(
user
.
id
,
merge_request
.
id
,
user
.
id
).
message
end
end
def
removed_milestone_merge_request_email
Notify
.
removed_milestone_merge_request_email
(
user
.
id
,
merge_request
.
id
,
user
.
id
)
end
def
changed_milestone_merge_request_email
Notify
.
changed_milestone_merge_request_email
(
user
.
id
,
merge_request
.
id
,
milestone
,
user
.
id
)
end
def
member_access_denied_email
def
member_access_denied_email
Notify
.
member_access_denied_email
(
'project'
,
project
.
id
,
user
.
id
).
message
Notify
.
member_access_denied_email
(
'project'
,
project
.
id
,
user
.
id
).
message
end
end
...
@@ -145,6 +161,10 @@ class NotifyPreview < ActionMailer::Preview
...
@@ -145,6 +161,10 @@ class NotifyPreview < ActionMailer::Preview
@merge_request
||=
project
.
merge_requests
.
first
@merge_request
||=
project
.
merge_requests
.
first
end
end
def
milestone
@milestone
||=
issue
.
milestone
end
def
pipeline
def
pipeline
@pipeline
=
Ci
::
Pipeline
.
last
@pipeline
=
Ci
::
Pipeline
.
last
end
end
...
...
app/services/issuable_base_service.rb
View file @
2ac20bc7
...
@@ -5,6 +5,14 @@ class IssuableBaseService < BaseService
...
@@ -5,6 +5,14 @@ class IssuableBaseService < BaseService
private
private
attr_accessor
:params
,
:skip_milestone_email
def
initialize
(
project
,
user
=
nil
,
params
=
{})
super
@skip_milestone_email
=
@params
.
delete
(
:skip_milestone_email
)
end
def
filter_params
(
issuable
)
def
filter_params
(
issuable
)
ability_name
=
:"admin_
#{
issuable
.
to_ability_name
}
"
ability_name
=
:"admin_
#{
issuable
.
to_ability_name
}
"
...
...
app/services/issues/update_service.rb
View file @
2ac20bc7
...
@@ -49,6 +49,8 @@ module Issues
...
@@ -49,6 +49,8 @@ module Issues
notification_service
.
async
.
relabeled_issue
(
issue
,
added_labels
,
current_user
)
notification_service
.
async
.
relabeled_issue
(
issue
,
added_labels
,
current_user
)
end
end
handle_milestone_change
(
issue
)
added_mentions
=
issue
.
mentioned_users
-
old_mentioned_users
added_mentions
=
issue
.
mentioned_users
-
old_mentioned_users
if
added_mentions
.
present?
if
added_mentions
.
present?
...
@@ -92,6 +94,18 @@ module Issues
...
@@ -92,6 +94,18 @@ module Issues
private
private
def
handle_milestone_change
(
issue
)
return
if
skip_milestone_email
return
unless
issue
.
previous_changes
.
include?
(
'milestone_id'
)
if
issue
.
milestone
.
nil?
notification_service
.
async
.
removed_milestone_issue
(
issue
,
current_user
)
else
notification_service
.
async
.
changed_milestone_issue
(
issue
,
issue
.
milestone
,
current_user
)
end
end
# rubocop: disable CodeReuse/ActiveRecord
# rubocop: disable CodeReuse/ActiveRecord
def
get_issue_if_allowed
(
id
,
board_group_id
=
nil
)
def
get_issue_if_allowed
(
id
,
board_group_id
=
nil
)
return
unless
id
return
unless
id
...
...
app/services/merge_requests/update_service.rb
View file @
2ac20bc7
...
@@ -60,6 +60,8 @@ module MergeRequests
...
@@ -60,6 +60,8 @@ module MergeRequests
merge_request
.
mark_as_unchecked
merge_request
.
mark_as_unchecked
end
end
handle_milestone_change
(
merge_request
)
added_labels
=
merge_request
.
labels
-
old_labels
added_labels
=
merge_request
.
labels
-
old_labels
if
added_labels
.
present?
if
added_labels
.
present?
notification_service
.
async
.
relabeled_merge_request
(
notification_service
.
async
.
relabeled_merge_request
(
...
@@ -107,6 +109,18 @@ module MergeRequests
...
@@ -107,6 +109,18 @@ module MergeRequests
private
private
def
handle_milestone_change
(
merge_request
)
return
if
skip_milestone_email
return
unless
merge_request
.
previous_changes
.
include?
(
'milestone_id'
)
if
merge_request
.
milestone
.
nil?
notification_service
.
async
.
removed_milestone_merge_request
(
merge_request
,
current_user
)
else
notification_service
.
async
.
changed_milestone_merge_request
(
merge_request
,
merge_request
.
milestone
,
current_user
)
end
end
def
create_branch_change_note
(
issuable
,
branch_type
,
old_branch
,
new_branch
)
def
create_branch_change_note
(
issuable
,
branch_type
,
old_branch
,
new_branch
)
SystemNoteService
.
change_branch
(
SystemNoteService
.
change_branch
(
issuable
,
issuable
.
project
,
current_user
,
branch_type
,
issuable
,
issuable
.
project
,
current_user
,
branch_type
,
...
...
app/services/milestones/destroy_service.rb
View file @
2ac20bc7
...
@@ -4,7 +4,7 @@ module Milestones
...
@@ -4,7 +4,7 @@ module Milestones
class
DestroyService
<
Milestones
::
BaseService
class
DestroyService
<
Milestones
::
BaseService
def
execute
(
milestone
)
def
execute
(
milestone
)
Milestone
.
transaction
do
Milestone
.
transaction
do
update_params
=
{
milestone:
nil
}
update_params
=
{
milestone:
nil
,
skip_milestone_email:
true
}
milestone
.
issues
.
each
do
|
issue
|
milestone
.
issues
.
each
do
|
issue
|
Issues
::
UpdateService
.
new
(
parent
,
current_user
,
update_params
).
execute
(
issue
)
Issues
::
UpdateService
.
new
(
parent
,
current_user
,
update_params
).
execute
(
issue
)
...
...
app/services/notification_service.rb
View file @
2ac20bc7
...
@@ -131,6 +131,14 @@ class NotificationService
...
@@ -131,6 +131,14 @@ class NotificationService
relabeled_resource_email
(
issue
,
added_labels
,
current_user
,
:relabeled_issue_email
)
relabeled_resource_email
(
issue
,
added_labels
,
current_user
,
:relabeled_issue_email
)
end
end
def
removed_milestone_issue
(
issue
,
current_user
)
removed_milestone_resource_email
(
issue
,
current_user
,
:removed_milestone_issue_email
)
end
def
changed_milestone_issue
(
issue
,
new_milestone
,
current_user
)
changed_milestone_resource_email
(
issue
,
new_milestone
,
current_user
,
:changed_milestone_issue_email
)
end
# When create a merge request we should send an email to:
# When create a merge request we should send an email to:
#
#
# * mr author
# * mr author
...
@@ -140,9 +148,6 @@ class NotificationService
...
@@ -140,9 +148,6 @@ class NotificationService
# * users with custom level checked with "new merge request"
# * users with custom level checked with "new merge request"
#
#
# In EE, approvers of the merge request are also included
# In EE, approvers of the merge request are also included
#
# In EE, approvers of the merge request are also included
#
def
new_merge_request
(
merge_request
,
current_user
)
def
new_merge_request
(
merge_request
,
current_user
)
new_resource_email
(
merge_request
,
:new_merge_request_email
)
new_resource_email
(
merge_request
,
:new_merge_request_email
)
end
end
...
@@ -212,6 +217,14 @@ class NotificationService
...
@@ -212,6 +217,14 @@ class NotificationService
relabeled_resource_email
(
merge_request
,
added_labels
,
current_user
,
:relabeled_merge_request_email
)
relabeled_resource_email
(
merge_request
,
added_labels
,
current_user
,
:relabeled_merge_request_email
)
end
end
def
removed_milestone_merge_request
(
merge_request
,
current_user
)
removed_milestone_resource_email
(
merge_request
,
current_user
,
:removed_milestone_merge_request_email
)
end
def
changed_milestone_merge_request
(
merge_request
,
new_milestone
,
current_user
)
changed_milestone_resource_email
(
merge_request
,
new_milestone
,
current_user
,
:changed_milestone_merge_request_email
)
end
def
close_mr
(
merge_request
,
current_user
)
def
close_mr
(
merge_request
,
current_user
)
close_resource_email
(
merge_request
,
current_user
,
:closed_merge_request_email
)
close_resource_email
(
merge_request
,
current_user
,
:closed_merge_request_email
)
end
end
...
@@ -504,6 +517,30 @@ class NotificationService
...
@@ -504,6 +517,30 @@ class NotificationService
end
end
end
end
def
removed_milestone_resource_email
(
target
,
current_user
,
method
)
recipients
=
NotificationRecipientService
.
build_recipients
(
target
,
current_user
,
action:
'removed_milestone'
)
recipients
.
each
do
|
recipient
|
mailer
.
send
(
method
,
recipient
.
user
.
id
,
target
.
id
,
current_user
.
id
).
deliver_later
end
end
def
changed_milestone_resource_email
(
target
,
milestone
,
current_user
,
method
)
recipients
=
NotificationRecipientService
.
build_recipients
(
target
,
current_user
,
action:
'changed_milestone'
)
recipients
.
each
do
|
recipient
|
mailer
.
send
(
method
,
recipient
.
user
.
id
,
target
.
id
,
milestone
,
current_user
.
id
).
deliver_later
end
end
def
reopen_resource_email
(
target
,
current_user
,
method
,
status
)
def
reopen_resource_email
(
target
,
current_user
,
method
,
status
)
recipients
=
NotificationRecipientService
.
build_recipients
(
target
,
current_user
,
action:
"reopen"
)
recipients
=
NotificationRecipientService
.
build_recipients
(
target
,
current_user
,
action:
"reopen"
)
...
...
app/views/notify/changed_milestone_issue_email.html.haml
0 → 100644
View file @
2ac20bc7
%p
Milestone changed to
%strong
=
link_to
(
@milestone
.
name
,
@milestone_url
)
app/views/notify/changed_milestone_issue_email.text.erb
0 → 100644
View file @
2ac20bc7
Milestone changed to
<%=
@milestone
.
name
%>
(
<%=
@milestone_url
%>
)
app/views/notify/changed_milestone_merge_request_email.html.haml
0 → 100644
View file @
2ac20bc7
%p
Milestone changed to
%strong
=
link_to
(
@milestone
.
name
,
@milestone_url
)
app/views/notify/changed_milestone_merge_request_email.text.erb
0 → 100644
View file @
2ac20bc7
Milestone changed to
<%=
@milestone
.
name
%>
(
<%=
@milestone_url
%>
)
app/views/notify/removed_milestone_issue_email.html.haml
0 → 100644
View file @
2ac20bc7
%p
Milestone removed
app/views/notify/removed_milestone_issue_email.text.erb
0 → 100644
View file @
2ac20bc7
Milestone removed
app/views/notify/removed_milestone_merge_request_email.html.haml
0 → 100644
View file @
2ac20bc7
%p
Milestone removed
app/views/notify/removed_milestone_merge_request_email.text.erb
0 → 100644
View file @
2ac20bc7
Milestone removed
changelogs/unreleased/ccr-51520_change_milestone_email.yml
0 → 100644
View file @
2ac20bc7
---
title
:
Add email for milestone change
merge_request
:
22279
author
:
type
:
added
doc/workflow/notifications.md
View file @
2ac20bc7
...
@@ -92,12 +92,16 @@ In most of the below cases, the notification will be sent to:
...
@@ -92,12 +92,16 @@ In most of the below cases, the notification will be sent to:
| Reassign issue | The above, plus the old assignee |
| Reassign issue | The above, plus the old assignee |
| Reopen issue | |
| Reopen issue | |
| Due issue | Participants and Custom notification level with this event selected |
| Due issue | Participants and Custom notification level with this event selected |
| Change milestone issue | Subscribers, participants mentioned, and Custom notification level with this event selected |
| Remove milestone issue | Subscribers, participants mentioned, and Custom notification level with this event selected |
| New merge request | |
| New merge request | |
| Push to merge request | Participants and Custom notification level with this event selected |
| Push to merge request | Participants and Custom notification level with this event selected |
| Reassign merge request | The above, plus the old assignee |
| Reassign merge request | The above, plus the old assignee |
| Close merge request | |
| Close merge request | |
| Reopen merge request | |
| Reopen merge request | |
| Merge merge request | |
| Merge merge request | |
| Change milestone merge request | Subscribers, participants mentioned, and Custom notification level with this event selected |
| Remove milestone merge request | Subscribers, participants mentioned, and Custom notification level with this event selected |
| New comment | The above, plus anyone mentioned by
`@username`
in the comment, with notification level "Mention" or higher |
| New comment | The above, plus anyone mentioned by
`@username`
in the comment, with notification level "Mention" or higher |
| Failed pipeline | The author of the pipeline |
| Failed pipeline | The author of the pipeline |
| Successful pipeline | The author of the pipeline, if they have the custom notification setting for successful pipelines set |
| Successful pipeline | The author of the pipeline, if they have the custom notification setting for successful pipelines set |
...
...
spec/services/issues/update_service_spec.rb
View file @
2ac20bc7
...
@@ -343,7 +343,42 @@ describe Issues::UpdateService, :mailer do
...
@@ -343,7 +343,42 @@ describe Issues::UpdateService, :mailer do
end
end
end
end
context
'when the milestone change'
do
context
'when the milestone is removed'
do
let!
(
:non_subscriber
)
{
create
(
:user
)
}
let!
(
:subscriber
)
do
create
(
:user
)
do
|
u
|
issue
.
toggle_subscription
(
u
,
project
)
project
.
add_developer
(
u
)
end
end
it_behaves_like
'system notes for milestones'
it
'sends notifications for subscribers of changed milestone'
do
issue
.
milestone
=
create
(
:milestone
)
issue
.
save
perform_enqueued_jobs
do
update_issue
(
milestone_id:
""
)
end
should_email
(
subscriber
)
should_not_email
(
non_subscriber
)
end
end
context
'when the milestone is changed'
do
let!
(
:non_subscriber
)
{
create
(
:user
)
}
let!
(
:subscriber
)
do
create
(
:user
)
do
|
u
|
issue
.
toggle_subscription
(
u
,
project
)
project
.
add_developer
(
u
)
end
end
it
'marks todos as done'
do
it
'marks todos as done'
do
update_issue
(
milestone:
create
(
:milestone
))
update_issue
(
milestone:
create
(
:milestone
))
...
@@ -351,6 +386,15 @@ describe Issues::UpdateService, :mailer do
...
@@ -351,6 +386,15 @@ describe Issues::UpdateService, :mailer do
end
end
it_behaves_like
'system notes for milestones'
it_behaves_like
'system notes for milestones'
it
'sends notifications for subscribers of changed milestone'
do
perform_enqueued_jobs
do
update_issue
(
milestone:
create
(
:milestone
))
end
should_email
(
subscriber
)
should_not_email
(
non_subscriber
)
end
end
end
context
'when the labels change'
do
context
'when the labels change'
do
...
@@ -374,7 +418,7 @@ describe Issues::UpdateService, :mailer do
...
@@ -374,7 +418,7 @@ describe Issues::UpdateService, :mailer do
let!
(
:non_subscriber
)
{
create
(
:user
)
}
let!
(
:non_subscriber
)
{
create
(
:user
)
}
let!
(
:subscriber
)
do
let!
(
:subscriber
)
do
create
(
:user
)
.
tap
do
|
u
|
create
(
:user
)
do
|
u
|
label
.
toggle_subscription
(
u
,
project
)
label
.
toggle_subscription
(
u
,
project
)
project
.
add_developer
(
u
)
project
.
add_developer
(
u
)
end
end
...
...
spec/services/merge_requests/update_service_spec.rb
View file @
2ac20bc7
...
@@ -344,7 +344,42 @@ describe MergeRequests::UpdateService, :mailer do
...
@@ -344,7 +344,42 @@ describe MergeRequests::UpdateService, :mailer do
end
end
end
end
context
'when the milestone change'
do
context
'when the milestone is removed'
do
let!
(
:non_subscriber
)
{
create
(
:user
)
}
let!
(
:subscriber
)
do
create
(
:user
)
do
|
u
|
merge_request
.
toggle_subscription
(
u
,
project
)
project
.
add_developer
(
u
)
end
end
it_behaves_like
'system notes for milestones'
it
'sends notifications for subscribers of changed milestone'
do
merge_request
.
milestone
=
create
(
:milestone
)
merge_request
.
save
perform_enqueued_jobs
do
update_merge_request
(
milestone_id:
""
)
end
should_email
(
subscriber
)
should_not_email
(
non_subscriber
)
end
end
context
'when the milestone is changed'
do
let!
(
:non_subscriber
)
{
create
(
:user
)
}
let!
(
:subscriber
)
do
create
(
:user
)
do
|
u
|
merge_request
.
toggle_subscription
(
u
,
project
)
project
.
add_developer
(
u
)
end
end
it
'marks pending todos as done'
do
it
'marks pending todos as done'
do
update_merge_request
({
milestone:
create
(
:milestone
)
})
update_merge_request
({
milestone:
create
(
:milestone
)
})
...
@@ -352,6 +387,15 @@ describe MergeRequests::UpdateService, :mailer do
...
@@ -352,6 +387,15 @@ describe MergeRequests::UpdateService, :mailer do
end
end
it_behaves_like
'system notes for milestones'
it_behaves_like
'system notes for milestones'
it
'sends notifications for subscribers of changed milestone'
do
perform_enqueued_jobs
do
update_merge_request
(
milestone:
create
(
:milestone
))
end
should_email
(
subscriber
)
should_not_email
(
non_subscriber
)
end
end
end
context
'when the labels change'
do
context
'when the labels change'
do
...
...
spec/services/notification_service_spec.rb
View file @
2ac20bc7
...
@@ -13,6 +13,54 @@ describe NotificationService, :mailer do
...
@@ -13,6 +13,54 @@ describe NotificationService, :mailer do
end
end
end
end
shared_examples
'altered milestone notification on issue'
do
it
'sends the email to the correct people'
do
should_email
(
subscriber_to_new_milestone
)
issue
.
assignees
.
each
do
|
a
|
should_email
(
a
)
end
should_email
(
@u_watcher
)
should_email
(
@u_guest_watcher
)
should_email
(
@u_participant_mentioned
)
should_email
(
@subscriber
)
should_email
(
@subscribed_participant
)
should_email
(
@watcher_and_subscriber
)
should_not_email
(
@u_guest_custom
)
should_not_email
(
@u_committer
)
should_not_email
(
@unsubscriber
)
should_not_email
(
@u_participating
)
should_not_email
(
@u_lazy_participant
)
should_not_email
(
issue
.
author
)
should_not_email
(
@u_disabled
)
should_not_email
(
@u_custom_global
)
should_not_email
(
@u_mentioned
)
end
end
shared_examples
'altered milestone notification on merge request'
do
it
'sends the email to the correct people'
do
should_email
(
subscriber_to_new_milestone
)
merge_request
.
assignees
.
each
do
|
a
|
should_email
(
a
)
end
should_email
(
@u_watcher
)
should_email
(
@u_guest_watcher
)
should_email
(
@u_participant_mentioned
)
should_email
(
@subscriber
)
should_email
(
@subscribed_participant
)
should_email
(
@watcher_and_subscriber
)
should_not_email
(
@u_guest_custom
)
should_not_email
(
@u_committer
)
should_not_email
(
@unsubscriber
)
should_not_email
(
@u_participating
)
should_not_email
(
@u_lazy_participant
)
should_not_email
(
merge_request
.
author
)
should_not_email
(
@u_disabled
)
should_not_email
(
@u_custom_global
)
should_not_email
(
@u_mentioned
)
end
end
shared_examples
'notifications for new mentions'
do
shared_examples
'notifications for new mentions'
do
it
'sends no emails when no new mentions are present'
do
it
'sends no emails when no new mentions are present'
do
send_notifications
send_notifications
...
@@ -952,6 +1000,96 @@ describe NotificationService, :mailer do
...
@@ -952,6 +1000,96 @@ describe NotificationService, :mailer do
end
end
end
end
describe
'#removed_milestone_issue'
do
it_behaves_like
'altered milestone notification on issue'
do
let
(
:milestone
)
{
create
(
:milestone
,
project:
project
,
issues:
[
issue
])
}
let!
(
:subscriber_to_new_milestone
)
{
create
(
:user
)
{
|
u
|
issue
.
toggle_subscription
(
u
,
project
)
}
}
before
do
notification
.
removed_milestone_issue
(
issue
,
issue
.
author
)
end
end
context
'confidential issues'
do
let
(
:author
)
{
create
(
:user
)
}
let
(
:assignee
)
{
create
(
:user
)
}
let
(
:non_member
)
{
create
(
:user
)
}
let
(
:member
)
{
create
(
:user
)
}
let
(
:guest
)
{
create
(
:user
)
}
let
(
:admin
)
{
create
(
:admin
)
}
let
(
:confidential_issue
)
{
create
(
:issue
,
:confidential
,
project:
project
,
title:
'Confidential issue'
,
author:
author
,
assignees:
[
assignee
])
}
let
(
:milestone
)
{
create
(
:milestone
,
project:
project
,
issues:
[
confidential_issue
])
}
it
"emails subscribers of the issue's milestone that can read the issue"
do
project
.
add_developer
(
member
)
project
.
add_guest
(
guest
)
confidential_issue
.
subscribe
(
non_member
,
project
)
confidential_issue
.
subscribe
(
author
,
project
)
confidential_issue
.
subscribe
(
assignee
,
project
)
confidential_issue
.
subscribe
(
member
,
project
)
confidential_issue
.
subscribe
(
guest
,
project
)
confidential_issue
.
subscribe
(
admin
,
project
)
reset_delivered_emails!
notification
.
removed_milestone_issue
(
confidential_issue
,
@u_disabled
)
should_not_email
(
non_member
)
should_not_email
(
guest
)
should_email
(
author
)
should_email
(
assignee
)
should_email
(
member
)
should_email
(
admin
)
end
end
end
describe
'#changed_milestone_issue'
do
it_behaves_like
'altered milestone notification on issue'
do
let
(
:new_milestone
)
{
create
(
:milestone
,
project:
project
,
issues:
[
issue
])
}
let!
(
:subscriber_to_new_milestone
)
{
create
(
:user
)
{
|
u
|
issue
.
toggle_subscription
(
u
,
project
)
}
}
before
do
notification
.
changed_milestone_issue
(
issue
,
new_milestone
,
issue
.
author
)
end
end
context
'confidential issues'
do
let
(
:author
)
{
create
(
:user
)
}
let
(
:assignee
)
{
create
(
:user
)
}
let
(
:non_member
)
{
create
(
:user
)
}
let
(
:member
)
{
create
(
:user
)
}
let
(
:guest
)
{
create
(
:user
)
}
let
(
:admin
)
{
create
(
:admin
)
}
let
(
:confidential_issue
)
{
create
(
:issue
,
:confidential
,
project:
project
,
title:
'Confidential issue'
,
author:
author
,
assignees:
[
assignee
])
}
let
(
:new_milestone
)
{
create
(
:milestone
,
project:
project
,
issues:
[
confidential_issue
])
}
it
"emails subscribers of the issue's milestone that can read the issue"
do
project
.
add_developer
(
member
)
project
.
add_guest
(
guest
)
confidential_issue
.
subscribe
(
non_member
,
project
)
confidential_issue
.
subscribe
(
author
,
project
)
confidential_issue
.
subscribe
(
assignee
,
project
)
confidential_issue
.
subscribe
(
member
,
project
)
confidential_issue
.
subscribe
(
guest
,
project
)
confidential_issue
.
subscribe
(
admin
,
project
)
reset_delivered_emails!
notification
.
changed_milestone_issue
(
confidential_issue
,
new_milestone
,
@u_disabled
)
should_not_email
(
non_member
)
should_not_email
(
guest
)
should_email
(
author
)
should_email
(
assignee
)
should_email
(
member
)
should_email
(
admin
)
end
end
end
describe
'#close_issue'
do
describe
'#close_issue'
do
before
do
before
do
update_custom_notification
(
:close_issue
,
@u_guest_custom
,
resource:
project
)
update_custom_notification
(
:close_issue
,
@u_guest_custom
,
resource:
project
)
...
@@ -1346,6 +1484,28 @@ describe NotificationService, :mailer do
...
@@ -1346,6 +1484,28 @@ describe NotificationService, :mailer do
end
end
end
end
describe
'#removed_milestone_merge_request'
do
it_behaves_like
'altered milestone notification on merge request'
do
let
(
:milestone
)
{
create
(
:milestone
,
project:
project
,
merge_requests:
[
merge_request
])
}
let!
(
:subscriber_to_new_milestone
)
{
create
(
:user
)
{
|
u
|
merge_request
.
toggle_subscription
(
u
,
project
)
}
}
before
do
notification
.
removed_milestone_merge_request
(
merge_request
,
merge_request
.
author
)
end
end
end
describe
'#changed_milestone_merge_request'
do
it_behaves_like
'altered milestone notification on merge request'
do
let
(
:new_milestone
)
{
create
(
:milestone
,
project:
project
,
merge_requests:
[
merge_request
])
}
let!
(
:subscriber_to_new_milestone
)
{
create
(
:user
)
{
|
u
|
merge_request
.
toggle_subscription
(
u
,
project
)
}
}
before
do
notification
.
changed_milestone_merge_request
(
merge_request
,
new_milestone
,
merge_request
.
author
)
end
end
end
describe
'#merge_request_unmergeable'
do
describe
'#merge_request_unmergeable'
do
it
"sends email to merge request author"
do
it
"sends email to merge request author"
do
notification
.
merge_request_unmergeable
(
merge_request
)
notification
.
merge_request_unmergeable
(
merge_request
)
...
...
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