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
0
Merge Requests
0
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
Jérome Perrin
gitlab-ce
Commits
f64b82e1
Commit
f64b82e1
authored
Apr 29, 2016
by
Stan Hu
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Support e-mail notifications for comments on project snippets
Closes #2334
parent
0652d925
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
69 additions
and
16 deletions
+69
-16
CHANGELOG
CHANGELOG
+1
-0
app/mailers/emails/notes.rb
app/mailers/emails/notes.rb
+8
-0
app/models/project_snippet.rb
app/models/project_snippet.rb
+2
-0
app/views/notify/note_snippet_email.html.haml
app/views/notify/note_snippet_email.html.haml
+1
-0
app/views/notify/note_snippet_email.text.erb
app/views/notify/note_snippet_email.text.erb
+8
-0
spec/services/notification_service_spec.rb
spec/services/notification_service_spec.rb
+49
-16
No files found.
CHANGELOG
View file @
f64b82e1
...
@@ -4,6 +4,7 @@ v 8.8.0 (unreleased)
...
@@ -4,6 +4,7 @@ v 8.8.0 (unreleased)
- Project#open_branches has been cleaned up and no longer loads entire records into memory.
- Project#open_branches has been cleaned up and no longer loads entire records into memory.
- Make build status canceled if any of the jobs was canceled and none failed
- Make build status canceled if any of the jobs was canceled and none failed
- Remove future dates from contribution calendar graph.
- Remove future dates from contribution calendar graph.
- Support e-mail notifications for comments on project snippets
- Use ActionDispatch Remote IP for Akismet checking
- Use ActionDispatch Remote IP for Akismet checking
- Fix error when visiting commit builds page before build was updated
- Fix error when visiting commit builds page before build was updated
- Add 'l' shortcut to open Label dropdown on issuables and 'i' to create new issue on a project
- Add 'l' shortcut to open Label dropdown on issuables and 'i' to create new issue on a project
...
...
app/mailers/emails/notes.rb
View file @
f64b82e1
...
@@ -28,6 +28,14 @@ module Emails
...
@@ -28,6 +28,14 @@ module Emails
mail_answer_thread
(
@merge_request
,
note_thread_options
(
recipient_id
))
mail_answer_thread
(
@merge_request
,
note_thread_options
(
recipient_id
))
end
end
def
note_snippet_email
(
recipient_id
,
note_id
)
setup_note_mail
(
note_id
,
recipient_id
)
@snippet
=
@note
.
noteable
@target_url
=
namespace_project_snippet_url
(
*
note_target_url_options
)
mail_answer_thread
(
@snippet
,
note_thread_options
(
recipient_id
))
end
private
private
def
note_target_url_options
def
note_target_url_options
...
...
app/models/project_snippet.rb
View file @
f64b82e1
...
@@ -22,4 +22,6 @@ class ProjectSnippet < Snippet
...
@@ -22,4 +22,6 @@ class ProjectSnippet < Snippet
# Scopes
# Scopes
scope
:fresh
,
->
{
order
(
"created_at DESC"
)
}
scope
:fresh
,
->
{
order
(
"created_at DESC"
)
}
participant
:author
,
:notes
end
end
app/views/notify/note_snippet_email.html.haml
0 → 100644
View file @
f64b82e1
=
render
'note_message'
app/views/notify/note_snippet_email.text.erb
0 → 100644
View file @
f64b82e1
New comment for Snippet
<%=
@snippet
.
id
%>
<%=
url_for
(
namespace_project_snippet_url
(
@snippet
.
project
.
namespace
,
@snippet
.
project
,
@snippet
,
anchor:
"note_
#{
@note
.
id
}
"
))
%>
Author:
<%=
@note
.
author_name
%>
<%=
@note
.
note
%>
spec/services/notification_service_spec.rb
View file @
f64b82e1
...
@@ -10,7 +10,7 @@ describe NotificationService, services: true do
...
@@ -10,7 +10,7 @@ describe NotificationService, services: true do
end
end
describe
'Keys'
do
describe
'Keys'
do
describe
:new_key
do
describe
'#new_key'
do
let!
(
:key
)
{
create
(
:personal_key
)
}
let!
(
:key
)
{
create
(
:personal_key
)
}
it
{
expect
(
notification
.
new_key
(
key
)).
to
be_truthy
}
it
{
expect
(
notification
.
new_key
(
key
)).
to
be_truthy
}
...
@@ -22,7 +22,7 @@ describe NotificationService, services: true do
...
@@ -22,7 +22,7 @@ describe NotificationService, services: true do
end
end
describe
'Email'
do
describe
'Email'
do
describe
:new_email
do
describe
'#new_email'
do
let!
(
:email
)
{
create
(
:email
)
}
let!
(
:email
)
{
create
(
:email
)
}
it
{
expect
(
notification
.
new_email
(
email
)).
to
be_truthy
}
it
{
expect
(
notification
.
new_email
(
email
)).
to
be_truthy
}
...
@@ -147,8 +147,8 @@ describe NotificationService, services: true do
...
@@ -147,8 +147,8 @@ describe NotificationService, services: true do
ActionMailer
::
Base
.
deliveries
.
clear
ActionMailer
::
Base
.
deliveries
.
clear
end
end
describe
:new_note
do
describe
'#new_note'
do
it
do
it
'notifies the team members'
do
notification
.
new_note
(
note
)
notification
.
new_note
(
note
)
# Notify all team members
# Notify all team members
...
@@ -177,6 +177,39 @@ describe NotificationService, services: true do
...
@@ -177,6 +177,39 @@ describe NotificationService, services: true do
end
end
end
end
context
'project snippet note'
do
let
(
:project
)
{
create
(
:empty_project
,
:public
)
}
let
(
:snippet
)
{
create
(
:project_snippet
,
project:
project
,
author:
create
(
:user
))
}
let
(
:note
)
{
create
(
:note_on_project_snippet
,
noteable:
snippet
,
project_id:
snippet
.
project
.
id
,
note:
'@all mentioned'
)
}
before
do
build_team
(
note
.
project
)
note
.
project
.
team
<<
[
note
.
author
,
:master
]
ActionMailer
::
Base
.
deliveries
.
clear
end
describe
'#new_note'
do
it
'notifies the team members'
do
notification
.
new_note
(
note
)
# Notify all team members
note
.
project
.
team
.
members
.
each
do
|
member
|
# User with disabled notification should not be notified
next
if
member
.
id
==
@u_disabled
.
id
# Author should not be notified
next
if
member
.
id
==
note
.
author
.
id
should_email
(
member
)
end
should_email
(
note
.
noteable
.
author
)
should_not_email
(
note
.
author
)
should_email
(
@u_mentioned
)
should_not_email
(
@u_disabled
)
should_email
(
@u_not_mentioned
)
end
end
end
context
'commit note'
do
context
'commit note'
do
let
(
:project
)
{
create
(
:project
,
:public
)
}
let
(
:project
)
{
create
(
:project
,
:public
)
}
let
(
:note
)
{
create
(
:note_on_commit
,
project:
project
)
}
let
(
:note
)
{
create
(
:note_on_commit
,
project:
project
)
}
...
@@ -187,7 +220,7 @@ describe NotificationService, services: true do
...
@@ -187,7 +220,7 @@ describe NotificationService, services: true do
allow_any_instance_of
(
Commit
).
to
receive
(
:author
).
and_return
(
@u_committer
)
allow_any_instance_of
(
Commit
).
to
receive
(
:author
).
and_return
(
@u_committer
)
end
end
describe
:new_note
,
:perform_enqueued_jobs
do
describe
'#new_note, #perform_enqueued_jobs'
do
it
do
it
do
notification
.
new_note
(
note
)
notification
.
new_note
(
note
)
...
@@ -230,7 +263,7 @@ describe NotificationService, services: true do
...
@@ -230,7 +263,7 @@ describe NotificationService, services: true do
ActionMailer
::
Base
.
deliveries
.
clear
ActionMailer
::
Base
.
deliveries
.
clear
end
end
describe
:new_issue
do
describe
'#new_issue'
do
it
do
it
do
notification
.
new_issue
(
issue
,
@u_disabled
)
notification
.
new_issue
(
issue
,
@u_disabled
)
...
@@ -289,7 +322,7 @@ describe NotificationService, services: true do
...
@@ -289,7 +322,7 @@ describe NotificationService, services: true do
end
end
end
end
describe
:reassigned_issue
do
describe
'#reassigned_issue'
do
it
'emails new assignee'
do
it
'emails new assignee'
do
notification
.
reassigned_issue
(
issue
,
@u_disabled
)
notification
.
reassigned_issue
(
issue
,
@u_disabled
)
...
@@ -419,7 +452,7 @@ describe NotificationService, services: true do
...
@@ -419,7 +452,7 @@ describe NotificationService, services: true do
end
end
end
end
describe
:close_issue
do
describe
'#close_issue'
do
it
'should sent email to issue assignee and issue author'
do
it
'should sent email to issue assignee and issue author'
do
notification
.
close_issue
(
issue
,
@u_disabled
)
notification
.
close_issue
(
issue
,
@u_disabled
)
...
@@ -435,7 +468,7 @@ describe NotificationService, services: true do
...
@@ -435,7 +468,7 @@ describe NotificationService, services: true do
end
end
end
end
describe
:reopen_issue
do
describe
'#reopen_issue'
do
it
'should send email to issue assignee and issue author'
do
it
'should send email to issue assignee and issue author'
do
notification
.
reopen_issue
(
issue
,
@u_disabled
)
notification
.
reopen_issue
(
issue
,
@u_disabled
)
...
@@ -461,7 +494,7 @@ describe NotificationService, services: true do
...
@@ -461,7 +494,7 @@ describe NotificationService, services: true do
ActionMailer
::
Base
.
deliveries
.
clear
ActionMailer
::
Base
.
deliveries
.
clear
end
end
describe
:new_merge_request
do
describe
'#new_merge_request'
do
it
do
it
do
notification
.
new_merge_request
(
merge_request
,
@u_disabled
)
notification
.
new_merge_request
(
merge_request
,
@u_disabled
)
...
@@ -483,7 +516,7 @@ describe NotificationService, services: true do
...
@@ -483,7 +516,7 @@ describe NotificationService, services: true do
end
end
end
end
describe
:reassigned_merge_request
do
describe
'#reassigned_merge_request'
do
it
do
it
do
notification
.
reassigned_merge_request
(
merge_request
,
merge_request
.
author
)
notification
.
reassigned_merge_request
(
merge_request
,
merge_request
.
author
)
...
@@ -498,7 +531,7 @@ describe NotificationService, services: true do
...
@@ -498,7 +531,7 @@ describe NotificationService, services: true do
end
end
end
end
describe
:relabel_merge_request
do
describe
'#relabel_merge_request'
do
let
(
:label
)
{
create
(
:label
,
merge_requests:
[
merge_request
])
}
let
(
:label
)
{
create
(
:label
,
merge_requests:
[
merge_request
])
}
let
(
:label2
)
{
create
(
:label
)
}
let
(
:label2
)
{
create
(
:label
)
}
let!
(
:subscriber_to_label
)
{
create
(
:user
).
tap
{
|
u
|
label
.
toggle_subscription
(
u
)
}
}
let!
(
:subscriber_to_label
)
{
create
(
:user
).
tap
{
|
u
|
label
.
toggle_subscription
(
u
)
}
}
...
@@ -527,7 +560,7 @@ describe NotificationService, services: true do
...
@@ -527,7 +560,7 @@ describe NotificationService, services: true do
end
end
end
end
describe
:closed_merge_request
do
describe
'#closed_merge_request'
do
it
do
it
do
notification
.
close_mr
(
merge_request
,
@u_disabled
)
notification
.
close_mr
(
merge_request
,
@u_disabled
)
...
@@ -542,7 +575,7 @@ describe NotificationService, services: true do
...
@@ -542,7 +575,7 @@ describe NotificationService, services: true do
end
end
end
end
describe
:merged_merge_request
do
describe
'#merged_merge_request'
do
it
do
it
do
notification
.
merge_mr
(
merge_request
,
@u_disabled
)
notification
.
merge_mr
(
merge_request
,
@u_disabled
)
...
@@ -557,7 +590,7 @@ describe NotificationService, services: true do
...
@@ -557,7 +590,7 @@ describe NotificationService, services: true do
end
end
end
end
describe
:reopen_merge_request
do
describe
'#reopen_merge_request'
do
it
do
it
do
notification
.
reopen_mr
(
merge_request
,
@u_disabled
)
notification
.
reopen_mr
(
merge_request
,
@u_disabled
)
...
@@ -581,7 +614,7 @@ describe NotificationService, services: true do
...
@@ -581,7 +614,7 @@ describe NotificationService, services: true do
ActionMailer
::
Base
.
deliveries
.
clear
ActionMailer
::
Base
.
deliveries
.
clear
end
end
describe
:project_was_moved
do
describe
'#project_was_moved'
do
it
do
it
do
notification
.
project_was_moved
(
project
,
"gitlab/gitlab"
)
notification
.
project_was_moved
(
project
,
"gitlab/gitlab"
)
...
...
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