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
4a35d4b6
Commit
4a35d4b6
authored
Apr 05, 2017
by
Valery Sizov
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[Multiple issue assignees] Fix a few specs
parent
15c27fce
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
58 additions
and
10 deletions
+58
-10
app/services/notification_recipient_service.rb
app/services/notification_recipient_service.rb
+2
-2
app/services/system_note_service.rb
app/services/system_note_service.rb
+5
-2
lib/gitlab/github_import/issue_formatter.rb
lib/gitlab/github_import/issue_formatter.rb
+1
-1
spec/lib/gitlab/github_import/issue_formatter_spec.rb
spec/lib/gitlab/github_import/issue_formatter_spec.rb
+5
-5
spec/services/system_note_service_spec.rb
spec/services/system_note_service_spec.rb
+45
-0
No files found.
app/services/notification_recipient_service.rb
View file @
4a35d4b6
...
@@ -8,7 +8,6 @@ class NotificationRecipientService
...
@@ -8,7 +8,6 @@ class NotificationRecipientService
@project
=
project
@project
=
project
end
end
# TODO: refactor this: previous_assignee argument can be a user object or an array which is not really nice
def
build_recipients
(
target
,
current_user
,
action:
nil
,
previous_assignee:
nil
,
skip_current_user:
true
)
def
build_recipients
(
target
,
current_user
,
action:
nil
,
previous_assignee:
nil
,
skip_current_user:
true
)
custom_action
=
build_custom_key
(
action
,
target
)
custom_action
=
build_custom_key
(
action
,
target
)
...
@@ -29,7 +28,8 @@ class NotificationRecipientService
...
@@ -29,7 +28,8 @@ class NotificationRecipientService
recipients
<<
previous_assignee
if
previous_assignee
recipients
<<
previous_assignee
if
previous_assignee
recipients
<<
target
.
assignee
recipients
<<
target
.
assignee
when
:reassign_issue
when
:reassign_issue
recipients
.
concat
(
previous_assignee
)
if
previous_assignee
.
any?
previous_assignees
=
Array
(
previous_assignee
)
recipients
.
concat
(
previous_assignees
)
if
previous_assignees
.
any?
recipients
.
concat
(
target
.
assignees
)
recipients
.
concat
(
target
.
assignees
)
end
end
...
...
app/services/system_note_service.rb
View file @
4a35d4b6
...
@@ -68,13 +68,16 @@ module SystemNoteService
...
@@ -68,13 +68,16 @@ module SystemNoteService
#
#
# Returns the created Note object
# Returns the created Note object
def
change_issue_assignees
(
issue
,
project
,
author
,
old_assignees
)
def
change_issue_assignees
(
issue
,
project
,
author
,
old_assignees
)
# TODO: basic implementation, should be improved before merging the MR
body
=
body
=
if
issue
.
assignees
.
any?
&&
old_assignees
.
any?
if
issue
.
assignees
.
any?
&&
old_assignees
.
any?
unassigned_users
=
old_assignees
-
issue
.
assignees
unassigned_users
=
old_assignees
-
issue
.
assignees
added_users
=
issue
.
assignees
.
to_a
-
old_assignees
added_users
=
issue
.
assignees
.
to_a
-
old_assignees
"assigned to
#{
added_users
.
map
(
&
:to_reference
).
to_sentence
}
and unassigned
#{
unassigned_users
.
map
(
&
:to_reference
).
to_sentence
}
"
text_parts
=
[]
text_parts
<<
"assigned to
#{
added_users
.
map
(
&
:to_reference
).
to_sentence
}
"
if
added_users
.
any?
text_parts
<<
"unassigned
#{
unassigned_users
.
map
(
&
:to_reference
).
to_sentence
}
"
if
unassigned_users
.
any?
text_parts
.
join
(
' and '
)
elsif
old_assignees
.
any?
elsif
old_assignees
.
any?
"removed all assignees"
"removed all assignees"
elsif
issue
.
assignees
.
any?
elsif
issue
.
assignees
.
any?
...
...
lib/gitlab/github_import/issue_formatter.rb
View file @
4a35d4b6
...
@@ -10,7 +10,7 @@ module Gitlab
...
@@ -10,7 +10,7 @@ module Gitlab
description:
description
,
description:
description
,
state:
state
,
state:
state
,
author_id:
author_id
,
author_id:
author_id
,
assignee_ids:
[
assignee_id
]
,
assignee_ids:
Array
(
assignee_id
)
,
created_at:
raw_data
.
created_at
,
created_at:
raw_data
.
created_at
,
updated_at:
raw_data
.
updated_at
updated_at:
raw_data
.
updated_at
}
}
...
...
spec/lib/gitlab/github_import/issue_formatter_spec.rb
View file @
4a35d4b6
...
@@ -43,7 +43,7 @@ describe Gitlab::GithubImport::IssueFormatter, lib: true do
...
@@ -43,7 +43,7 @@ describe Gitlab::GithubImport::IssueFormatter, lib: true do
description:
"*Created by: octocat*
\n\n
I'm having a problem with this."
,
description:
"*Created by: octocat*
\n\n
I'm having a problem with this."
,
state:
'opened'
,
state:
'opened'
,
author_id:
project
.
creator_id
,
author_id:
project
.
creator_id
,
assignee_id
:
nil
,
assignee_id
s:
[]
,
created_at:
created_at
,
created_at:
created_at
,
updated_at:
updated_at
updated_at:
updated_at
}
}
...
@@ -64,7 +64,7 @@ describe Gitlab::GithubImport::IssueFormatter, lib: true do
...
@@ -64,7 +64,7 @@ describe Gitlab::GithubImport::IssueFormatter, lib: true do
description:
"*Created by: octocat*
\n\n
I'm having a problem with this."
,
description:
"*Created by: octocat*
\n\n
I'm having a problem with this."
,
state:
'closed'
,
state:
'closed'
,
author_id:
project
.
creator_id
,
author_id:
project
.
creator_id
,
assignee_id
:
nil
,
assignee_id
s:
[]
,
created_at:
created_at
,
created_at:
created_at
,
updated_at:
updated_at
updated_at:
updated_at
}
}
...
@@ -77,19 +77,19 @@ describe Gitlab::GithubImport::IssueFormatter, lib: true do
...
@@ -77,19 +77,19 @@ describe Gitlab::GithubImport::IssueFormatter, lib: true do
let
(
:raw_data
)
{
double
(
base_data
.
merge
(
assignee:
octocat
))
}
let
(
:raw_data
)
{
double
(
base_data
.
merge
(
assignee:
octocat
))
}
it
'returns nil as assignee_id when is not a GitLab user'
do
it
'returns nil as assignee_id when is not a GitLab user'
do
expect
(
issue
.
attributes
.
fetch
(
:assignee_id
)).
to
be_nil
expect
(
issue
.
attributes
.
fetch
(
:assignee_id
s
)).
to
be_empty
end
end
it
'returns GitLab user id associated with GitHub id as assignee_id'
do
it
'returns GitLab user id associated with GitHub id as assignee_id'
do
gl_user
=
create
(
:omniauth_user
,
extern_uid:
octocat
.
id
,
provider:
'github'
)
gl_user
=
create
(
:omniauth_user
,
extern_uid:
octocat
.
id
,
provider:
'github'
)
expect
(
issue
.
attributes
.
fetch
(
:assignee_id
)).
to
eq
gl_user
.
id
expect
(
issue
.
attributes
.
fetch
(
:assignee_id
s
)).
to
eq
[
gl_user
.
id
]
end
end
it
'returns GitLab user id associated with GitHub email as assignee_id'
do
it
'returns GitLab user id associated with GitHub email as assignee_id'
do
gl_user
=
create
(
:user
,
email:
octocat
.
email
)
gl_user
=
create
(
:user
,
email:
octocat
.
email
)
expect
(
issue
.
attributes
.
fetch
(
:assignee_id
)).
to
eq
gl_user
.
id
expect
(
issue
.
attributes
.
fetch
(
:assignee_id
s
)).
to
eq
[
gl_user
.
id
]
end
end
end
end
...
...
spec/services/system_note_service_spec.rb
View file @
4a35d4b6
...
@@ -6,6 +6,7 @@ describe SystemNoteService, services: true do
...
@@ -6,6 +6,7 @@ describe SystemNoteService, services: true do
let
(
:project
)
{
create
(
:project
)
}
let
(
:project
)
{
create
(
:project
)
}
let
(
:author
)
{
create
(
:user
)
}
let
(
:author
)
{
create
(
:user
)
}
let
(
:noteable
)
{
create
(
:issue
,
project:
project
)
}
let
(
:noteable
)
{
create
(
:issue
,
project:
project
)
}
let
(
:issue
)
{
noteable
}
shared_examples_for
'a system note'
do
shared_examples_for
'a system note'
do
it
'is valid'
do
it
'is valid'
do
...
@@ -133,6 +134,50 @@ describe SystemNoteService, services: true do
...
@@ -133,6 +134,50 @@ describe SystemNoteService, services: true do
end
end
end
end
describe
'.change_issue_assignees'
do
subject
{
described_class
.
change_issue_assignees
(
noteable
,
project
,
author
,
[
assignee
])
}
let
(
:assignee
)
{
create
(
:user
)
}
let
(
:assignee1
)
{
create
(
:user
)
}
let
(
:assignee2
)
{
create
(
:user
)
}
let
(
:assignee3
)
{
create
(
:user
)
}
it_behaves_like
'a system note'
def
build_note
(
old_assignees
,
new_assignees
)
issue
.
assignees
=
new_assignees
described_class
.
change_issue_assignees
(
issue
,
project
,
author
,
old_assignees
).
note
end
it
'builds a correct phrase when an assignee is added to a non-assigned issue'
do
expect
(
build_note
([],
[
assignee1
])).
to
eq
"assigned to @
#{
assignee1
.
username
}
"
end
it
'builds a correct phrase when assignee removed'
do
expect
(
build_note
([
assignee1
],
[])).
to
eq
'removed all assignees'
end
it
'builds a correct phrase when assignees changed'
do
expect
(
build_note
([
assignee1
],
[
assignee2
])).
to
eq
\
"assigned to @
#{
assignee2
.
username
}
and unassigned @
#{
assignee1
.
username
}
"
end
it
'builds a correct phrase when three assignees removed and one added'
do
expect
(
build_note
([
assignee
,
assignee1
,
assignee2
],
[
assignee3
])).
to
eq
\
"assigned to @
#{
assignee3
.
username
}
and unassigned @
#{
assignee
.
username
}
, @
#{
assignee1
.
username
}
, and @
#{
assignee2
.
username
}
"
end
it
'builds a correct phrase when one assignee changed from a set'
do
expect
(
build_note
([
assignee
,
assignee1
],
[
assignee
,
assignee2
])).
to
eq
\
"assigned to @
#{
assignee2
.
username
}
and unassigned @
#{
assignee1
.
username
}
"
end
it
'builds a correct phrase when one assignee removed from a set'
do
expect
(
build_note
([
assignee
,
assignee1
,
assignee2
],
[
assignee
,
assignee1
])).
to
eq
\
"unassigned @
#{
assignee2
.
username
}
"
end
end
describe
'.change_label'
do
describe
'.change_label'
do
subject
{
described_class
.
change_label
(
noteable
,
project
,
author
,
added
,
removed
)
}
subject
{
described_class
.
change_label
(
noteable
,
project
,
author
,
added
,
removed
)
}
...
...
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