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
0ce00442
Commit
0ce00442
authored
Feb 14, 2022
by
Doug Stull
Committed by
Alex Pooley
Feb 14, 2022
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Allows invite modal to re-invite single users
- regression from original invite with non-modal Changelog: fixed
parent
2fc43ac5
Changes
6
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
217 additions
and
14 deletions
+217
-14
app/services/concerns/members/bulk_create_users.rb
app/services/concerns/members/bulk_create_users.rb
+1
-0
app/services/members/creator_service.rb
app/services/members/creator_service.rb
+1
-0
lib/api/helpers/members_helpers.rb
lib/api/helpers/members_helpers.rb
+0
-9
spec/requests/api/members_spec.rb
spec/requests/api/members_spec.rb
+119
-3
spec/services/members/create_service_spec.rb
spec/services/members/create_service_spec.rb
+18
-0
spec/support/shared_examples/models/member_shared_examples.rb
.../support/shared_examples/models/member_shared_examples.rb
+78
-2
No files found.
app/services/concerns/members/bulk_create_users.rb
View file @
0ce00442
...
@@ -48,6 +48,7 @@ module Members
...
@@ -48,6 +48,7 @@ module Members
end
end
if
user_ids
.
present?
if
user_ids
.
present?
# we should handle the idea of existing members where users are passed as users - https://gitlab.com/gitlab-org/gitlab/-/issues/352617
# the below will automatically discard invalid user_ids
# the below will automatically discard invalid user_ids
users
.
concat
(
User
.
id_in
(
user_ids
))
users
.
concat
(
User
.
id_in
(
user_ids
))
# helps not have to perform another query per user id to see if the member exists later on when fetching
# helps not have to perform another query per user id to see if the member exists later on when fetching
...
...
app/services/members/creator_service.rb
View file @
0ce00442
...
@@ -67,6 +67,7 @@ module Members
...
@@ -67,6 +67,7 @@ module Members
def
create_member_task
def
create_member_task
return
unless
member
.
persisted?
return
unless
member
.
persisted?
return
if
member_task_attributes
.
value?
(
nil
)
return
if
member_task_attributes
.
value?
(
nil
)
return
if
member
.
member_task
.
present?
member
.
create_member_task
(
member_task_attributes
)
member
.
create_member_task
(
member_task_attributes
)
end
end
...
...
lib/api/helpers/members_helpers.rb
View file @
0ce00442
...
@@ -62,13 +62,10 @@ module API
...
@@ -62,13 +62,10 @@ module API
end
end
def
add_single_member_by_user_id
(
create_service_params
)
def
add_single_member_by_user_id
(
create_service_params
)
source
=
create_service_params
[
:source
]
user_id
=
create_service_params
[
:user_ids
]
user_id
=
create_service_params
[
:user_ids
]
user
=
User
.
find_by
(
id:
user_id
)
# rubocop: disable CodeReuse/ActiveRecord
user
=
User
.
find_by
(
id:
user_id
)
# rubocop: disable CodeReuse/ActiveRecord
if
user
if
user
conflict!
(
'Member already exists'
)
if
member_already_exists?
(
source
,
user_id
)
instance
=
::
Members
::
CreateService
.
new
(
current_user
,
create_service_params
)
instance
=
::
Members
::
CreateService
.
new
(
current_user
,
create_service_params
)
instance
.
execute
instance
.
execute
...
@@ -90,12 +87,6 @@ module API
...
@@ -90,12 +87,6 @@ module API
def
add_single_member?
(
user_id
)
def
add_single_member?
(
user_id
)
user_id
.
present?
user_id
.
present?
end
end
private
def
member_already_exists?
(
source
,
user_id
)
source
.
members
.
exists?
(
user_id:
user_id
)
# rubocop: disable CodeReuse/ActiveRecord
end
end
end
end
end
end
end
...
...
spec/requests/api/members_spec.rb
View file @
0ce00442
...
@@ -291,6 +291,25 @@ RSpec.describe API::Members do
...
@@ -291,6 +291,25 @@ RSpec.describe API::Members do
user:
maintainer
user:
maintainer
)
)
end
end
context
'with an already existing member'
do
before
do
source
.
add_developer
(
stranger
)
end
it
'tracks the invite source from params'
do
post
api
(
"/
#{
source_type
.
pluralize
}
/
#{
source
.
id
}
/members"
,
maintainer
),
params:
params
.
merge
(
invite_source:
'_invite_source_'
)
expect_snowplow_event
(
category:
'Members::CreateService'
,
action:
'create_member'
,
label:
'_invite_source_'
,
property:
'existing_user'
,
user:
maintainer
)
end
end
end
end
context
'when executing the Members::CreateService for multiple user_ids'
do
context
'when executing the Members::CreateService for multiple user_ids'
do
...
@@ -399,6 +418,49 @@ RSpec.describe API::Members do
...
@@ -399,6 +418,49 @@ RSpec.describe API::Members do
expect
(
member
.
tasks_to_be_done
).
to
match_array
([
:code
,
:ci
])
expect
(
member
.
tasks_to_be_done
).
to
match_array
([
:code
,
:ci
])
expect
(
member
.
member_task
.
project_id
).
to
eq
(
project_id
)
expect
(
member
.
member_task
.
project_id
).
to
eq
(
project_id
)
end
end
context
'with already existing member'
do
before
do
source
.
add_developer
(
stranger
)
end
it
'does not update tasks to be done if tasks already exist'
,
:aggregate_failures
do
member
=
source
.
members
.
find_by
(
user_id:
stranger
.
id
)
create
(
:member_task
,
member:
member
,
project_id:
project_id
,
tasks_to_be_done:
%w(code ci)
)
expect
do
post
api
(
"/
#{
source_type
.
pluralize
}
/
#{
source
.
id
}
/members"
,
maintainer
),
params:
{
user_id:
stranger
.
id
,
access_level:
Member
::
DEVELOPER
,
tasks_to_be_done:
%w(issues)
,
tasks_project_id:
project_id
}
end
.
not_to
change
(
MemberTask
,
:count
)
member
.
reset
expect
(
response
).
to
have_gitlab_http_status
(
:created
)
expect
(
member
.
tasks_to_be_done
).
to
match_array
([
:code
,
:ci
])
expect
(
member
.
member_task
.
project_id
).
to
eq
(
project_id
)
end
it
'adds tasks to be done if they do not exist'
,
:aggregate_failures
do
expect
do
post
api
(
"/
#{
source_type
.
pluralize
}
/
#{
source
.
id
}
/members"
,
maintainer
),
params:
{
user_id:
stranger
.
id
,
access_level:
Member
::
DEVELOPER
,
tasks_to_be_done:
%w(issues)
,
tasks_project_id:
project_id
}
end
.
to
change
(
MemberTask
,
:count
).
by
(
1
)
member
=
source
.
members
.
find_by
(
user_id:
stranger
.
id
)
expect
(
response
).
to
have_gitlab_http_status
(
:created
)
expect
(
member
.
tasks_to_be_done
).
to
match_array
([
:issues
])
expect
(
member
.
member_task
.
project_id
).
to
eq
(
project_id
)
end
end
end
end
context
'when there are multiple users to add'
do
context
'when there are multiple users to add'
do
...
@@ -412,14 +474,68 @@ RSpec.describe API::Members do
...
@@ -412,14 +474,68 @@ RSpec.describe API::Members do
expect
(
member
.
member_task
.
project_id
).
to
eq
(
project_id
)
expect
(
member
.
member_task
.
project_id
).
to
eq
(
project_id
)
end
end
end
end
context
'with already existing members'
do
before
do
source
.
add_developer
(
stranger
)
source
.
add_developer
(
developer
)
end
it
'does not update tasks to be done if tasks already exist'
,
:aggregate_failures
do
members
=
source
.
members
.
where
(
user_id:
[
developer
.
id
,
stranger
.
id
])
members
.
each
do
|
member
|
create
(
:member_task
,
member:
member
,
project_id:
project_id
,
tasks_to_be_done:
%w(code ci)
)
end
expect
do
post
api
(
"/
#{
source_type
.
pluralize
}
/
#{
source
.
id
}
/members"
,
maintainer
),
params:
{
user_id:
[
developer
.
id
,
stranger
.
id
].
join
(
','
),
access_level:
Member
::
DEVELOPER
,
tasks_to_be_done:
%w(issues)
,
tasks_project_id:
project_id
}
end
.
not_to
change
(
MemberTask
,
:count
)
expect
(
response
).
to
have_gitlab_http_status
(
:created
)
members
.
each
do
|
member
|
member
.
reset
expect
(
member
.
tasks_to_be_done
).
to
match_array
([
:code
,
:ci
])
expect
(
member
.
member_task
.
project_id
).
to
eq
(
project_id
)
end
end
end
end
it
"returns 409 if member already exists"
do
it
'adds tasks to be done if they do not exist'
,
:aggregate_failures
do
expect
do
post
api
(
"/
#{
source_type
.
pluralize
}
/
#{
source
.
id
}
/members"
,
maintainer
),
post
api
(
"/
#{
source_type
.
pluralize
}
/
#{
source
.
id
}
/members"
,
maintainer
),
params:
{
user_id:
maintainer
.
id
,
access_level:
Member
::
MAINTAINER
}
params:
{
user_id:
[
developer
.
id
,
stranger
.
id
].
join
(
','
),
access_level:
Member
::
DEVELOPER
,
tasks_to_be_done:
%w(issues)
,
tasks_project_id:
project_id
}
end
.
to
change
(
MemberTask
,
:count
).
by
(
2
)
expect
(
response
).
to
have_gitlab_http_status
(
:conflict
)
expect
(
response
).
to
have_gitlab_http_status
(
:created
)
members
=
source
.
members
.
where
(
user_id:
[
developer
.
id
,
stranger
.
id
])
members
.
each
do
|
member
|
expect
(
member
.
tasks_to_be_done
).
to
match_array
([
:issues
])
expect
(
member
.
member_task
.
project_id
).
to
eq
(
project_id
)
end
end
end
end
end
it
"updates a current member"
do
source
.
add_guest
(
stranger
)
post
api
(
"/
#{
source_type
.
pluralize
}
/
#{
source
.
id
}
/members"
,
maintainer
),
params:
{
user_id:
stranger
.
id
,
access_level:
Member
::
MAINTAINER
}
expect
(
response
).
to
have_gitlab_http_status
(
:created
)
expect
(
json_response
[
'id'
]).
to
eq
(
stranger
.
id
)
expect
(
json_response
[
'access_level'
]).
to
eq
(
Member
::
MAINTAINER
)
end
end
it
'returns 404 when the user_id is not valid'
do
it
'returns 404 when the user_id is not valid'
do
...
...
spec/services/members/create_service_spec.rb
View file @
0ce00442
...
@@ -117,6 +117,24 @@ RSpec.describe Members::CreateService, :aggregate_failures, :clean_gitlab_redis_
...
@@ -117,6 +117,24 @@ RSpec.describe Members::CreateService, :aggregate_failures, :clean_gitlab_redis_
user:
user
user:
user
)
)
end
end
context
'with an already existing member'
do
before
do
source
.
add_developer
(
member
)
end
it
'tracks the invite source from params'
do
execute_service
expect_snowplow_event
(
category:
described_class
.
name
,
action:
'create_member'
,
label:
'_invite_source_'
,
property:
'existing_user'
,
user:
user
)
end
end
end
end
context
'when it is a net_new_user'
do
context
'when it is a net_new_user'
do
...
...
spec/support/shared_examples/models/member_shared_examples.rb
View file @
0ce00442
...
@@ -301,8 +301,9 @@ RSpec.shared_examples_for "member creation" do
...
@@ -301,8 +301,9 @@ RSpec.shared_examples_for "member creation" do
end
end
context
'when `tasks_to_be_done` and `tasks_project_id` are passed'
do
context
'when `tasks_to_be_done` and `tasks_project_id` are passed'
do
let
(
:task_project
)
{
source
.
is_a?
(
Group
)
?
create
(
:project
,
group:
source
)
:
source
}
it
'creates a member_task with the correct attributes'
,
:aggregate_failures
do
it
'creates a member_task with the correct attributes'
,
:aggregate_failures
do
task_project
=
source
.
is_a?
(
Group
)
?
create
(
:project
,
group:
source
)
:
source
described_class
.
new
(
source
,
user
,
:developer
,
tasks_to_be_done:
%w(ci code)
,
tasks_project_id:
task_project
.
id
).
execute
described_class
.
new
(
source
,
user
,
:developer
,
tasks_to_be_done:
%w(ci code)
,
tasks_project_id:
task_project
.
id
).
execute
member
=
source
.
members
.
last
member
=
source
.
members
.
last
...
@@ -310,6 +311,43 @@ RSpec.shared_examples_for "member creation" do
...
@@ -310,6 +311,43 @@ RSpec.shared_examples_for "member creation" do
expect
(
member
.
tasks_to_be_done
).
to
match_array
([
:ci
,
:code
])
expect
(
member
.
tasks_to_be_done
).
to
match_array
([
:ci
,
:code
])
expect
(
member
.
member_task
.
project
).
to
eq
(
task_project
)
expect
(
member
.
member_task
.
project
).
to
eq
(
task_project
)
end
end
context
'with an already existing member'
do
before
do
source
.
add_user
(
user
,
:developer
)
end
it
'does not update tasks to be done if tasks already exist'
,
:aggregate_failures
do
member
=
source
.
members
.
find_by
(
user_id:
user
.
id
)
create
(
:member_task
,
member:
member
,
project:
task_project
,
tasks_to_be_done:
%w(code ci)
)
expect
do
described_class
.
new
(
source
,
user
,
:developer
,
tasks_to_be_done:
%w(issues)
,
tasks_project_id:
task_project
.
id
).
execute
end
.
not_to
change
(
MemberTask
,
:count
)
member
.
reset
expect
(
member
.
tasks_to_be_done
).
to
match_array
([
:code
,
:ci
])
expect
(
member
.
member_task
.
project
).
to
eq
(
task_project
)
end
it
'adds tasks to be done if they do not exist'
,
:aggregate_failures
do
expect
do
described_class
.
new
(
source
,
user
,
:developer
,
tasks_to_be_done:
%w(issues)
,
tasks_project_id:
task_project
.
id
).
execute
end
.
to
change
(
MemberTask
,
:count
).
by
(
1
)
member
=
source
.
members
.
find_by
(
user_id:
user
.
id
)
expect
(
member
.
tasks_to_be_done
).
to
match_array
([
:issues
])
expect
(
member
.
member_task
.
project
).
to
eq
(
task_project
)
end
end
end
end
end
end
end
end
...
@@ -393,14 +431,52 @@ RSpec.shared_examples_for "bulk member creation" do
...
@@ -393,14 +431,52 @@ RSpec.shared_examples_for "bulk member creation" do
end
end
context
'when `tasks_to_be_done` and `tasks_project_id` are passed'
do
context
'when `tasks_to_be_done` and `tasks_project_id` are passed'
do
let
(
:task_project
)
{
source
.
is_a?
(
Group
)
?
create
(
:project
,
group:
source
)
:
source
}
it
'creates a member_task with the correct attributes'
,
:aggregate_failures
do
it
'creates a member_task with the correct attributes'
,
:aggregate_failures
do
task_project
=
source
.
is_a?
(
Group
)
?
create
(
:project
,
group:
source
)
:
source
members
=
described_class
.
add_users
(
source
,
[
user1
],
:developer
,
tasks_to_be_done:
%w(ci code)
,
tasks_project_id:
task_project
.
id
)
members
=
described_class
.
add_users
(
source
,
[
user1
],
:developer
,
tasks_to_be_done:
%w(ci code)
,
tasks_project_id:
task_project
.
id
)
member
=
members
.
last
member
=
members
.
last
expect
(
member
.
tasks_to_be_done
).
to
match_array
([
:ci
,
:code
])
expect
(
member
.
tasks_to_be_done
).
to
match_array
([
:ci
,
:code
])
expect
(
member
.
member_task
.
project
).
to
eq
(
task_project
)
expect
(
member
.
member_task
.
project
).
to
eq
(
task_project
)
end
end
context
'with an already existing member'
do
before
do
source
.
add_user
(
user1
,
:developer
)
end
it
'does not update tasks to be done if tasks already exist'
,
:aggregate_failures
do
member
=
source
.
members
.
find_by
(
user_id:
user1
.
id
)
create
(
:member_task
,
member:
member
,
project:
task_project
,
tasks_to_be_done:
%w(code ci)
)
expect
do
described_class
.
add_users
(
source
,
[
user1
.
id
],
:developer
,
tasks_to_be_done:
%w(issues)
,
tasks_project_id:
task_project
.
id
)
end
.
not_to
change
(
MemberTask
,
:count
)
member
.
reset
expect
(
member
.
tasks_to_be_done
).
to
match_array
([
:code
,
:ci
])
expect
(
member
.
member_task
.
project
).
to
eq
(
task_project
)
end
it
'adds tasks to be done if they do not exist'
,
:aggregate_failures
do
expect
do
described_class
.
add_users
(
source
,
[
user1
.
id
],
:developer
,
tasks_to_be_done:
%w(issues)
,
tasks_project_id:
task_project
.
id
)
end
.
to
change
(
MemberTask
,
:count
).
by
(
1
)
member
=
source
.
members
.
find_by
(
user_id:
user1
.
id
)
expect
(
member
.
tasks_to_be_done
).
to
match_array
([
:issues
])
expect
(
member
.
member_task
.
project
).
to
eq
(
task_project
)
end
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