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
6a5781c4
Commit
6a5781c4
authored
Apr 21, 2017
by
Dmitriy Zaporozhets
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Refactor add_users method for project and group
Signed-off-by:
Dmitriy Zaporozhets
<
dmitriy.zaporozhets@gmail.com
>
parent
0997a5ae
Changes
9
Show whitespace changes
Inline
Side-by-side
Showing
9 changed files
with
53 additions
and
32 deletions
+53
-32
app/models/group.rb
app/models/group.rb
+1
-1
app/models/member.rb
app/models/member.rb
+16
-12
app/models/members/group_member.rb
app/models/members/group_member.rb
+0
-12
app/models/members/project_member.rb
app/models/members/project_member.rb
+2
-2
app/models/project_team.rb
app/models/project_team.rb
+2
-2
changelogs/unreleased/dz-cleanup-add-users.yml
changelogs/unreleased/dz-cleanup-add-users.yml
+4
-0
spec/controllers/projects/labels_controller_spec.rb
spec/controllers/projects/labels_controller_spec.rb
+1
-1
spec/models/member_spec.rb
spec/models/member_spec.rb
+25
-0
spec/models/members/group_member_spec.rb
spec/models/members/group_member_spec.rb
+2
-2
No files found.
app/models/group.rb
View file @
6a5781c4
...
...
@@ -141,7 +141,7 @@ class Group < Namespace
end
def
add_users
(
users
,
access_level
,
current_user:
nil
,
expires_at:
nil
)
GroupMember
.
add_users
_to_group
(
GroupMember
.
add_users
(
self
,
users
,
access_level
,
...
...
app/models/member.rb
View file @
6a5781c4
...
...
@@ -154,6 +154,22 @@ class Member < ActiveRecord::Base
member
end
def
add_users
(
source
,
users
,
access_level
,
current_user:
nil
,
expires_at:
nil
)
return
[]
unless
users
.
present?
self
.
transaction
do
users
.
map
do
|
user
|
add_user
(
source
,
user
,
access_level
,
current_user:
current_user
,
expires_at:
expires_at
)
end
end
end
def
access_levels
Gitlab
::
Access
.
sym_options
end
...
...
@@ -176,18 +192,6 @@ class Member < ActiveRecord::Base
# There is no current user for bulk actions, in which case anything is allowed
!
current_user
||
current_user
.
can?
(
:"update_
#{
member
.
type
.
underscore
}
"
,
member
)
end
def
add_users_to_source
(
source
,
users
,
access_level
,
current_user:
nil
,
expires_at:
nil
)
users
.
each
do
|
user
|
add_user
(
source
,
user
,
access_level
,
current_user:
current_user
,
expires_at:
expires_at
)
end
end
end
def
real_source_type
...
...
app/models/members/group_member.rb
View file @
6a5781c4
...
...
@@ -26,18 +26,6 @@ class GroupMember < Member
Gitlab
::
Access
.
sym_options_with_owner
end
def
self
.
add_users_to_group
(
group
,
users
,
access_level
,
current_user:
nil
,
expires_at:
nil
)
self
.
transaction
do
add_users_to_source
(
group
,
users
,
access_level
,
current_user:
current_user
,
expires_at:
expires_at
)
end
end
def
group
source
end
...
...
app/models/members/project_member.rb
View file @
6a5781c4
...
...
@@ -17,7 +17,7 @@ class ProjectMember < Member
before_destroy
:delete_member_branch_protection
class
<<
self
# Add users to project
team
s with passed access option
# Add users to projects with passed access option
#
# access can be an integer representing a access code
# or symbol like :master representing role
...
...
@@ -40,7 +40,7 @@ class ProjectMember < Member
project_ids
.
each
do
|
project_id
|
project
=
Project
.
find
(
project_id
)
add_users
_to_source
(
add_users
(
project
,
users
,
access_level
,
...
...
app/models/project_team.rb
View file @
6a5781c4
...
...
@@ -52,8 +52,8 @@ class ProjectTeam
def
add_users
(
users
,
access_level
,
current_user:
nil
,
expires_at:
nil
)
return
false
if
group_member_lock
ProjectMember
.
add_users
_to_projects
(
[
project
.
id
]
,
ProjectMember
.
add_users
(
project
,
users
,
access_level
,
current_user:
current_user
,
...
...
changelogs/unreleased/dz-cleanup-add-users.yml
0 → 100644
View file @
6a5781c4
---
title
:
Refactor add_users method for project and group
merge_request
:
10850
author
:
spec/controllers/projects/labels_controller_spec.rb
View file @
6a5781c4
...
...
@@ -127,7 +127,7 @@ describe Projects::LabelsController do
context
'group owner'
do
before
do
GroupMember
.
add_users
_to_group
(
group
,
[
user
],
:owner
)
GroupMember
.
add_users
(
group
,
[
user
],
:owner
)
end
it
'gives access'
do
...
...
spec/models/member_spec.rb
View file @
6a5781c4
...
...
@@ -386,6 +386,31 @@ describe Member, models: true do
end
end
describe
'.add_users'
do
%w[project group]
.
each
do
|
source_type
|
context
"when source is a
#{
source_type
}
"
do
let!
(
:source
)
{
create
(
source_type
,
:public
,
:access_requestable
)
}
let!
(
:user
)
{
create
(
:user
)
}
let!
(
:admin
)
{
create
(
:admin
)
}
it
'returns a <Source>Member objects'
do
members
=
described_class
.
add_users
(
source
,
[
user
],
:master
)
expect
(
members
).
to
be_a
Array
expect
(
members
.
first
).
to
be_a
"
#{
source_type
.
classify
}
Member"
.
constantize
expect
(
members
.
first
).
to
be_persisted
end
it
'returns an empty array'
do
members
=
described_class
.
add_users
(
source
,
[],
:master
)
expect
(
members
).
to
be_a
Array
expect
(
members
).
to
be_empty
end
end
end
end
describe
'#accept_request'
do
let
(
:member
)
{
create
(
:project_member
,
requested_at:
Time
.
now
.
utc
)
}
...
...
spec/models/members/group_member_spec.rb
View file @
6a5781c4
...
...
@@ -13,12 +13,12 @@ describe GroupMember, models: true do
end
end
describe
'.add_users
_to_group
'
do
describe
'.add_users'
do
it
'adds the given users to the given group'
do
group
=
create
(
:group
)
users
=
create_list
(
:user
,
2
)
described_class
.
add_users
_to_group
(
described_class
.
add_users
(
group
,
[
users
.
first
.
id
,
users
.
second
],
described_class
::
MASTER
...
...
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