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
3537786f
Commit
3537786f
authored
May 05, 2021
by
peterhegman
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Refactor passed members data to one JSON data attribute
Instead of multiple data attributes
parent
faee533c
Changes
17
Show whitespace changes
Inline
Side-by-side
Showing
17 changed files
with
171 additions
and
189 deletions
+171
-189
app/assets/javascripts/members/index.js
app/assets/javascripts/members/index.js
+1
-1
app/assets/javascripts/members/utils.js
app/assets/javascripts/members/utils.js
+6
-16
app/helpers/groups/group_members_helper.rb
app/helpers/groups/group_members_helper.rb
+21
-11
app/helpers/members_helper.rb
app/helpers/members_helper.rb
+2
-2
app/helpers/projects/project_members_helper.rb
app/helpers/projects/project_members_helper.rb
+22
-12
app/views/groups/group_members/index.html.haml
app/views/groups/group_members/index.html.haml
+4
-4
app/views/projects/project_members/index.html.haml
app/views/projects/project_members/index.html.haml
+4
-4
ee/app/assets/javascripts/members/utils.js
ee/app/assets/javascripts/members/utils.js
+1
-14
ee/app/helpers/ee/groups/group_members_helper.rb
ee/app/helpers/ee/groups/group_members_helper.rb
+2
-2
ee/spec/frontend/members/index_spec.js
ee/spec/frontend/members/index_spec.js
+2
-5
ee/spec/frontend/members/utils_spec.js
ee/spec/frontend/members/utils_spec.js
+2
-42
ee/spec/helpers/ee/groups/group_members_helper_spec.rb
ee/spec/helpers/ee/groups/group_members_helper_spec.rb
+5
-3
spec/frontend/members/index_spec.js
spec/frontend/members/index_spec.js
+2
-6
spec/frontend/members/mock_data.js
spec/frontend/members/mock_data.js
+11
-2
spec/frontend/members/utils_spec.js
spec/frontend/members/utils_spec.js
+12
-13
spec/helpers/groups/group_members_helper_spec.rb
spec/helpers/groups/group_members_helper_spec.rb
+37
-26
spec/helpers/projects/project_members_helper_spec.rb
spec/helpers/projects/project_members_helper_spec.rb
+37
-26
No files found.
app/assets/javascripts/members/index.js
View file @
3537786f
import
{
GlToast
}
from
'
@gitlab/ui
'
;
import
{
GlToast
}
from
'
@gitlab/ui
'
;
import
Vue
from
'
vue
'
;
import
Vue
from
'
vue
'
;
import
Vuex
from
'
vuex
'
;
import
Vuex
from
'
vuex
'
;
import
{
parseDataAttributes
}
from
'
ee_else_ce
/members/utils
'
;
import
{
parseDataAttributes
}
from
'
~
/members/utils
'
;
import
App
from
'
./components/app.vue
'
;
import
App
from
'
./components/app.vue
'
;
import
membersStore
from
'
./store
'
;
import
membersStore
from
'
./store
'
;
...
...
app/assets/javascripts/members/utils.js
View file @
3537786f
import
{
isUndefined
}
from
'
lodash
'
;
import
{
isUndefined
}
from
'
lodash
'
;
import
{
import
{
getParameterByName
,
convertObjectPropsToCamelCase
}
from
'
~/lib/utils/common_utils
'
;
getParameterByName
,
convertObjectPropsToCamelCase
,
parseBoolean
,
}
from
'
~/lib/utils/common_utils
'
;
import
{
setUrlParams
}
from
'
~/lib/utils/url_utility
'
;
import
{
setUrlParams
}
from
'
~/lib/utils/url_utility
'
;
import
{
__
}
from
'
~/locale
'
;
import
{
__
}
from
'
~/locale
'
;
import
{
import
{
...
@@ -105,18 +101,12 @@ export const buildSortHref = ({
...
@@ -105,18 +101,12 @@ export const buildSortHref = ({
export
const
canOverride
=
()
=>
false
;
export
const
canOverride
=
()
=>
false
;
export
const
parseDataAttributes
=
(
el
)
=>
{
export
const
parseDataAttributes
=
(
el
)
=>
{
const
{
members
,
pagination
,
sourceId
,
memberPath
,
canManageMembers
}
=
el
.
dataset
;
const
{
data
}
=
el
.
dataset
;
return
{
return
convertObjectPropsToCamelCase
(
JSON
.
parse
(
data
),
{
members
:
convertObjectPropsToCamelCase
(
JSON
.
parse
(
members
),
{
deep
:
true
}),
pagination
:
convertObjectPropsToCamelCase
(
JSON
.
parse
(
pagination
||
'
{}
'
),
{
deep
:
true
,
deep
:
true
,
ignoreKeyNames
:
[
'
params
'
],
ignoreKeyNames
:
[
'
params
'
],
}),
});
sourceId
:
parseInt
(
sourceId
,
10
),
memberPath
,
canManageMembers
:
parseBoolean
(
canManageMembers
),
};
};
};
export
const
baseRequestFormatter
=
(
basePropertyName
,
accessLevelPropertyName
)
=>
({
export
const
baseRequestFormatter
=
(
basePropertyName
,
accessLevelPropertyName
)
=>
({
...
...
app/helpers/groups/group_members_helper.rb
View file @
3537786f
...
@@ -13,31 +13,41 @@ module Groups::GroupMembersHelper
...
@@ -13,31 +13,41 @@ module Groups::GroupMembersHelper
render
'shared/members/invite_member'
,
submit_url:
group_group_members_path
(
group
),
access_levels:
group
.
access_level_roles
,
default_access_level:
default_access_level
render
'shared/members/invite_member'
,
submit_url:
group_group_members_path
(
group
),
access_levels:
group
.
access_level_roles
,
default_access_level:
default_access_level
end
end
def
group_
group_links_data_json
(
group_links
)
def
group_
members_list_data_json
(
group
,
members
,
pagination
=
{}
)
GroupLink
::
GroupGroupLinkSerializer
.
new
.
represent
(
group_links
,
{
current_user:
current_user
}
).
to_json
group_members_list_data
(
group
,
members
,
pagination
).
to_json
end
end
def
members_data_json
(
group
,
members
)
def
group_group_links_list_data_json
(
group
)
MemberSerializer
.
new
.
represent
(
members
,
{
current_user:
current_user
,
group:
group
,
source:
group
}).
to_json
group_group_links_list_data
(
group
).
to_json
end
private
def
group_members_serialized
(
group
,
members
)
MemberSerializer
.
new
.
represent
(
members
,
{
current_user:
current_user
,
group:
group
,
source:
group
})
end
def
group_group_links_serialized
(
group_links
)
GroupLink
::
GroupGroupLinkSerializer
.
new
.
represent
(
group_links
,
{
current_user:
current_user
})
end
end
# Overridden in `ee/app/helpers/ee/groups/group_members_helper.rb`
# Overridden in `ee/app/helpers/ee/groups/group_members_helper.rb`
def
group_members_list_data
_attributes
(
group
,
members
,
pagination
=
{}
)
def
group_members_list_data
(
group
,
members
,
pagination
)
{
{
members:
members_data_json
(
group
,
members
),
members:
group_members_serialized
(
group
,
members
),
pagination:
members_pagination_data
_json
(
members
,
pagination
),
pagination:
members_pagination_data
(
members
,
pagination
),
member_path:
group_group_member_path
(
group
,
':id'
),
member_path:
group_group_member_path
(
group
,
':id'
),
source_id:
group
.
id
,
source_id:
group
.
id
,
can_manage_members:
can?
(
current_user
,
:admin_group_member
,
group
)
.
to_s
can_manage_members:
can?
(
current_user
,
:admin_group_member
,
group
)
}
}
end
end
def
group_group_links_list_data
_attributes
(
group
)
def
group_group_links_list_data
(
group
)
group_links
=
group
.
shared_with_group_links
group_links
=
group
.
shared_with_group_links
{
{
members:
group_group_links_
data_json
(
group_links
),
members:
group_group_links_
serialized
(
group_links
),
pagination:
members_pagination_data
_json
(
group_links
),
pagination:
members_pagination_data
(
group_links
),
member_path:
group_group_link_path
(
group
,
':id'
),
member_path:
group_group_link_path
(
group
,
':id'
),
source_id:
group
.
id
source_id:
group
.
id
}
}
...
...
app/helpers/members_helper.rb
View file @
3537786f
...
@@ -66,13 +66,13 @@ module MembersHelper
...
@@ -66,13 +66,13 @@ module MembersHelper
'group and any subresources'
'group and any subresources'
end
end
def
members_pagination_data
_json
(
members
,
pagination
=
{})
def
members_pagination_data
(
members
,
pagination
=
{})
{
{
current_page:
members
.
respond_to?
(
:current_page
)
?
members
.
current_page
:
nil
,
current_page:
members
.
respond_to?
(
:current_page
)
?
members
.
current_page
:
nil
,
per_page:
members
.
respond_to?
(
:limit_value
)
?
members
.
limit_value
:
nil
,
per_page:
members
.
respond_to?
(
:limit_value
)
?
members
.
limit_value
:
nil
,
total_items:
members
.
respond_to?
(
:total_count
)
?
members
.
total_count
:
members
.
count
,
total_items:
members
.
respond_to?
(
:total_count
)
?
members
.
total_count
:
members
.
count
,
param_name:
pagination
[
:param_name
]
||
nil
,
param_name:
pagination
[
:param_name
]
||
nil
,
params:
pagination
[
:params
]
||
{}
params:
pagination
[
:params
]
||
{}
}
.
to_json
}
end
end
end
end
app/helpers/projects/project_members_helper.rb
View file @
3537786f
...
@@ -27,31 +27,41 @@ module Projects::ProjectMembersHelper
...
@@ -27,31 +27,41 @@ module Projects::ProjectMembersHelper
project
.
group
.
has_owner?
(
current_user
)
project
.
group
.
has_owner?
(
current_user
)
end
end
def
project_
group_links_data_json
(
group_links
)
def
project_
members_list_data_json
(
project
,
members
,
pagination
=
{}
)
GroupLink
::
ProjectGroupLinkSerializer
.
new
.
represent
(
group_links
,
{
current_user:
current_user
}
).
to_json
project_members_list_data
(
project
,
members
,
pagination
).
to_json
end
end
def
project_
members_data_json
(
project
,
member
s
)
def
project_
group_links_list_data_json
(
project
,
group_link
s
)
MemberSerializer
.
new
.
represent
(
members
,
{
current_user:
current_user
,
group:
project
.
group
,
source:
project
}
).
to_json
project_group_links_list_data
(
project
,
group_links
).
to_json
end
end
def
project_members_list_data_attributes
(
project
,
members
,
pagination
=
{})
private
def
project_members_serialized
(
project
,
members
)
MemberSerializer
.
new
.
represent
(
members
,
{
current_user:
current_user
,
group:
project
.
group
,
source:
project
})
end
def
project_group_links_serialized
(
group_links
)
GroupLink
::
ProjectGroupLinkSerializer
.
new
.
represent
(
group_links
,
{
current_user:
current_user
})
end
def
project_members_list_data
(
project
,
members
,
pagination
)
{
{
members:
project_members_
data_json
(
project
,
members
),
members:
project_members_
serialized
(
project
,
members
),
pagination:
members_pagination_data
_json
(
members
,
pagination
),
pagination:
members_pagination_data
(
members
,
pagination
),
member_path:
project_project_member_path
(
project
,
':id'
),
member_path:
project_project_member_path
(
project
,
':id'
),
source_id:
project
.
id
,
source_id:
project
.
id
,
can_manage_members:
can_manage_project_members?
(
project
)
.
to_s
can_manage_members:
can_manage_project_members?
(
project
)
}
}
end
end
def
project_group_links_list_data
_attributes
(
project
,
group_links
)
def
project_group_links_list_data
(
project
,
group_links
)
{
{
members:
project_group_links_
data_json
(
group_links
),
members:
project_group_links_
serialized
(
group_links
),
pagination:
members_pagination_data
_json
(
group_links
),
pagination:
members_pagination_data
(
group_links
),
member_path:
project_group_link_path
(
project
,
':id'
),
member_path:
project_group_link_path
(
project
,
':id'
),
source_id:
project
.
id
,
source_id:
project
.
id
,
can_manage_members:
can_manage_project_members?
(
project
)
.
to_s
can_manage_members:
can_manage_project_members?
(
project
)
}
}
end
end
end
end
app/views/groups/group_members/index.html.haml
View file @
3537786f
...
@@ -61,21 +61,21 @@
...
@@ -61,21 +61,21 @@
%span
.badge.gl-tab-counter-badge.badge-muted.badge-pill.gl-badge.sm
=
@requesters
.
count
%span
.badge.gl-tab-counter-badge.badge-muted.badge-pill.gl-badge.sm
=
@requesters
.
count
.tab-content
.tab-content
#tab-members
.tab-pane
{
class:
(
'active'
unless
invited_active
)
}
#tab-members
.tab-pane
{
class:
(
'active'
unless
invited_active
)
}
.js-group-members-list
{
data:
group_members_list_data_attributes
(
@group
,
@members
,
{
param_name: :page
,
params:
{
invited_members_page:
nil
,
search_invited:
nil
}
})
}
.js-group-members-list
{
data:
{
data:
group_members_list_data_json
(
@group
,
@members
,
{
param_name: :page
,
params:
{
invited_members_page:
nil
,
search_invited:
nil
}
})
}
}
.loading
.loading
.gl-spinner.gl-spinner-md
.gl-spinner.gl-spinner-md
-
if
@group
.
shared_with_group_links
.
present?
-
if
@group
.
shared_with_group_links
.
present?
#tab-groups
.tab-pane
#tab-groups
.tab-pane
.js-group-group-links-list
{
data:
group_group_links_list_data_attributes
(
@group
)
}
.js-group-group-links-list
{
data:
{
data:
group_group_links_list_data_json
(
@group
)
}
}
.loading
.loading
.gl-spinner.gl-spinner-md
.gl-spinner.gl-spinner-md
-
if
show_invited_members
-
if
show_invited_members
#tab-invited-members
.tab-pane
{
class:
(
'active'
if
invited_active
)
}
#tab-invited-members
.tab-pane
{
class:
(
'active'
if
invited_active
)
}
.js-group-invited-members-list
{
data:
group_members_list_data_attributes
(
@group
,
@invited_members
,
{
param_name: :invited_members_page
,
params:
{
page:
nil
}
})
}
.js-group-invited-members-list
{
data:
{
data:
group_members_list_data_json
(
@group
,
@invited_members
,
{
param_name: :invited_members_page
,
params:
{
page:
nil
}
})
}
}
.loading
.loading
.gl-spinner.gl-spinner-md
.gl-spinner.gl-spinner-md
-
if
show_access_requests
-
if
show_access_requests
#tab-access-requests
.tab-pane
#tab-access-requests
.tab-pane
.js-group-access-requests-list
{
data:
group_members_list_data_attributes
(
@group
,
@requesters
)
}
.js-group-access-requests-list
{
data:
{
data:
group_members_list_data_json
(
@group
,
@requesters
)
}
}
.loading
.loading
.gl-spinner.gl-spinner-md
.gl-spinner.gl-spinner-md
app/views/projects/project_members/index.html.haml
View file @
3537786f
...
@@ -82,21 +82,21 @@
...
@@ -82,21 +82,21 @@
%span
.badge.gl-tab-counter-badge.badge-muted.badge-pill.gl-badge.sm
=
@requesters
.
count
%span
.badge.gl-tab-counter-badge.badge-muted.badge-pill.gl-badge.sm
=
@requesters
.
count
.tab-content
.tab-content
#tab-members
.tab-pane
{
class:
(
'active'
unless
groups_tab_active?
)
}
#tab-members
.tab-pane
{
class:
(
'active'
unless
groups_tab_active?
)
}
.js-project-members-list
{
data:
project_members_list_data_attributes
(
@project
,
@project_members
,
{
param_name: :page
,
params:
{
search_groups:
nil
}
})
}
.js-project-members-list
{
data:
{
data:
project_members_list_data_json
(
@project
,
@project_members
,
{
param_name: :page
,
params:
{
search_groups:
nil
}
})
}
}
.loading
.loading
.gl-spinner.gl-spinner-md
.gl-spinner.gl-spinner-md
-
if
show_groups?
(
@group_links
)
-
if
show_groups?
(
@group_links
)
#tab-groups
.tab-pane
{
class:
(
'active'
if
groups_tab_active?
)
}
#tab-groups
.tab-pane
{
class:
(
'active'
if
groups_tab_active?
)
}
.js-project-group-links-list
{
data:
project_group_links_list_data_attributes
(
@project
,
@group_links
)
}
.js-project-group-links-list
{
data:
{
data:
project_group_links_list_data_json
(
@project
,
@group_links
)
}
}
.loading
.loading
.gl-spinner.gl-spinner-md
.gl-spinner.gl-spinner-md
-
if
show_invited_members?
(
@project
,
@invited_members
)
-
if
show_invited_members?
(
@project
,
@invited_members
)
#tab-invited-members
.tab-pane
#tab-invited-members
.tab-pane
.js-project-invited-members-list
{
data:
project_members_list_data_attributes
(
@project
,
@invited_members
)
}
.js-project-invited-members-list
{
data:
{
data:
project_members_list_data_json
(
@project
,
@invited_members
)
}
}
.loading
.loading
.gl-spinner.gl-spinner-md
.gl-spinner.gl-spinner-md
-
if
show_access_requests?
(
@project
,
@requesters
)
-
if
show_access_requests?
(
@project
,
@requesters
)
#tab-access-requests
.tab-pane
#tab-access-requests
.tab-pane
.js-project-access-requests-list
{
data:
project_members_list_data_attributes
(
@project
,
@requesters
)
}
.js-project-access-requests-list
{
data:
{
data:
project_members_list_data_json
(
@project
,
@requesters
)
}
}
.loading
.loading
.gl-spinner.gl-spinner-md
.gl-spinner.gl-spinner-md
ee/app/assets/javascripts/members/utils.js
View file @
3537786f
import
{
__
}
from
'
~/locale
'
;
import
{
__
}
from
'
~/locale
'
;
import
{
import
{
generateBadges
as
CEGenerateBadges
,
isDirectMember
}
from
'
~/members/utils
'
;
generateBadges
as
CEGenerateBadges
,
parseDataAttributes
as
CEParseDataAttributes
,
isDirectMember
,
}
from
'
~/members/utils
'
;
export
{
export
{
isGroup
,
isGroup
,
...
@@ -39,12 +35,3 @@ export const generateBadges = ({ member, isCurrentUser, canManageMembers }) => [
...
@@ -39,12 +35,3 @@ export const generateBadges = ({ member, isCurrentUser, canManageMembers }) => [
];
];
export
const
canOverride
=
(
member
)
=>
member
.
canOverride
&&
isDirectMember
(
member
);
export
const
canOverride
=
(
member
)
=>
member
.
canOverride
&&
isDirectMember
(
member
);
export
const
parseDataAttributes
=
(
el
)
=>
{
const
{
ldapOverridePath
}
=
el
.
dataset
;
return
{
...
CEParseDataAttributes
(
el
),
ldapOverridePath
,
};
};
ee/app/helpers/ee/groups/group_members_helper.rb
View file @
3537786f
...
@@ -8,8 +8,8 @@ module EE::Groups::GroupMembersHelper
...
@@ -8,8 +8,8 @@ module EE::Groups::GroupMembersHelper
super
.
merge
(
skip_ldap:
@group
.
ldap_synced?
)
super
.
merge
(
skip_ldap:
@group
.
ldap_synced?
)
end
end
override
:group_members_list_data
_attributes
override
:group_members_list_data
def
group_members_list_data
_attributes
(
group
,
_members
,
_pagination
=
{})
def
group_members_list_data
(
group
,
_members
,
_pagination
=
{})
super
.
merge!
({
super
.
merge!
({
ldap_override_path:
override_group_group_member_path
(
group
,
':id'
)
ldap_override_path:
override_group_group_member_path
(
group
,
':id'
)
})
})
...
...
ee/spec/frontend/members/index_spec.js
View file @
3537786f
import
{
membersJsonString
}
from
'
jest/members/mock_data
'
;
import
{
dataAttribute
}
from
'
jest/members/mock_data
'
;
import
{
MEMBER_TYPES
}
from
'
~/members/constants
'
;
import
{
MEMBER_TYPES
}
from
'
~/members/constants
'
;
import
{
initMembersApp
}
from
'
~/members/index
'
;
import
{
initMembersApp
}
from
'
~/members/index
'
;
...
@@ -14,10 +14,7 @@ describe('initMembersApp', () => {
...
@@ -14,10 +14,7 @@ describe('initMembersApp', () => {
beforeEach
(()
=>
{
beforeEach
(()
=>
{
el
=
document
.
createElement
(
'
div
'
);
el
=
document
.
createElement
(
'
div
'
);
el
.
setAttribute
(
'
data-members
'
,
membersJsonString
);
el
.
setAttribute
(
'
data-data
'
,
dataAttribute
);
el
.
setAttribute
(
'
data-source-id
'
,
'
234
'
);
el
.
setAttribute
(
'
data-member-path
'
,
'
/groups/foo-bar/-/group_members/:id
'
);
el
.
setAttribute
(
'
data-ldap-override-path
'
,
'
/groups/ldap-group/-/group_members/:id/override
'
);
});
});
afterEach
(()
=>
{
afterEach
(()
=>
{
...
...
ee/spec/frontend/members/utils_spec.js
View file @
3537786f
import
{
generateBadges
,
canOverride
,
parseDataAttributes
}
from
'
ee/members/utils
'
;
import
{
generateBadges
,
canOverride
}
from
'
ee/members/utils
'
;
import
{
import
{
member
as
memberMock
,
directMember
,
inheritedMember
}
from
'
jest/members/mock_data
'
;
member
as
memberMock
,
directMember
,
inheritedMember
,
membersJsonString
,
members
,
paginationJsonString
,
pagination
,
}
from
'
jest/members/mock_data
'
;
describe
(
'
Members Utils
'
,
()
=>
{
describe
(
'
Members Utils
'
,
()
=>
{
describe
(
'
generateBadges
'
,
()
=>
{
describe
(
'
generateBadges
'
,
()
=>
{
...
@@ -53,36 +45,4 @@ describe('Members Utils', () => {
...
@@ -53,36 +45,4 @@ describe('Members Utils', () => {
expect
(
canOverride
(
member
)).
toBe
(
expected
);
expect
(
canOverride
(
member
)).
toBe
(
expected
);
});
});
});
});
describe
(
'
group member utils
'
,
()
=>
{
describe
(
'
parseDataAttributes
'
,
()
=>
{
let
el
;
beforeEach
(()
=>
{
el
=
document
.
createElement
(
'
div
'
);
el
.
setAttribute
(
'
data-members
'
,
membersJsonString
);
el
.
setAttribute
(
'
data-pagination
'
,
paginationJsonString
);
el
.
setAttribute
(
'
data-source-id
'
,
'
234
'
);
el
.
setAttribute
(
'
data-can-manage-members
'
,
'
true
'
);
el
.
setAttribute
(
'
data-ldap-override-path
'
,
'
/groups/ldap-group/-/group_members/:id/override
'
,
);
});
afterEach
(()
=>
{
el
=
null
;
});
it
(
'
correctly parses the data attributes
'
,
()
=>
{
expect
(
parseDataAttributes
(
el
)).
toEqual
({
members
,
pagination
,
sourceId
:
234
,
canManageMembers
:
true
,
ldapOverridePath
:
'
/groups/ldap-group/-/group_members/:id/override
'
,
});
});
});
});
});
});
ee/spec/helpers/ee/groups/group_members_helper_spec.rb
View file @
3537786f
...
@@ -22,15 +22,17 @@ RSpec.describe Groups::GroupMembersHelper do
...
@@ -22,15 +22,17 @@ RSpec.describe Groups::GroupMembersHelper do
end
end
end
end
describe
'#group_members_list_data_attributes'
do
describe
'#group_members_list_data_json'
do
subject
{
Gitlab
::
Json
.
parse
(
helper
.
group_members_list_data_json
(
group
,
[]))
}
before
do
before
do
allow
(
helper
).
to
receive
(
:override_group_group_member_path
).
with
(
group
,
':id'
).
and_return
(
'/groups/foo-bar/-/group_members/:id/override'
)
allow
(
helper
).
to
receive
(
:override_group_group_member_path
).
with
(
group
,
':id'
).
and_return
(
'/groups/foo-bar/-/group_members/:id/override'
)
allow
(
helper
).
to
receive
(
:group_group_member_path
).
with
(
group
,
':id'
).
and_return
(
'/groups/foo-bar/-/group_members/:id'
)
allow
(
helper
).
to
receive
(
:group_group_member_path
).
with
(
group
,
':id'
).
and_return
(
'/groups/foo-bar/-/group_members/:id'
)
allow
(
helper
).
to
receive
(
:can?
).
with
(
current_user
,
:admin_group_member
,
group
).
and_return
(
true
)
allow
(
helper
).
to
receive
(
:can?
).
with
(
current_user
,
:admin_group_member
,
group
).
and_return
(
true
)
end
end
it
'adds `ldap_override_path` to returned
hash
'
do
it
'adds `ldap_override_path` to returned
json
'
do
expect
(
helper
.
group_members_list_data_attributes
(
group
,
[])).
to
include
(
ldap_override_path:
'/groups/foo-bar/-/group_members/:id/override'
)
expect
(
subject
[
'ldap_override_path'
]).
to
eq
(
'/groups/foo-bar/-/group_members/:id/override'
)
end
end
end
end
end
end
spec/frontend/members/index_spec.js
View file @
3537786f
...
@@ -2,7 +2,7 @@ import { createWrapper } from '@vue/test-utils';
...
@@ -2,7 +2,7 @@ import { createWrapper } from '@vue/test-utils';
import
MembersApp
from
'
~/members/components/app.vue
'
;
import
MembersApp
from
'
~/members/components/app.vue
'
;
import
{
MEMBER_TYPES
}
from
'
~/members/constants
'
;
import
{
MEMBER_TYPES
}
from
'
~/members/constants
'
;
import
{
initMembersApp
}
from
'
~/members/index
'
;
import
{
initMembersApp
}
from
'
~/members/index
'
;
import
{
members
JsonString
,
members
,
paginationJsonString
,
pagination
}
from
'
./mock_data
'
;
import
{
members
,
pagination
,
dataAttribute
}
from
'
./mock_data
'
;
describe
(
'
initMembersApp
'
,
()
=>
{
describe
(
'
initMembersApp
'
,
()
=>
{
let
el
;
let
el
;
...
@@ -23,11 +23,7 @@ describe('initMembersApp', () => {
...
@@ -23,11 +23,7 @@ describe('initMembersApp', () => {
beforeEach
(()
=>
{
beforeEach
(()
=>
{
el
=
document
.
createElement
(
'
div
'
);
el
=
document
.
createElement
(
'
div
'
);
el
.
setAttribute
(
'
data-members
'
,
membersJsonString
);
el
.
setAttribute
(
'
data-data
'
,
dataAttribute
);
el
.
setAttribute
(
'
data-pagination
'
,
paginationJsonString
);
el
.
setAttribute
(
'
data-source-id
'
,
'
234
'
);
el
.
setAttribute
(
'
data-can-manage-members
'
,
'
true
'
);
el
.
setAttribute
(
'
data-member-path
'
,
'
/groups/foo-bar/-/group_members/:id
'
);
window
.
gon
=
{
current_user_id
:
123
};
window
.
gon
=
{
current_user_id
:
123
};
});
});
...
...
spec/frontend/members/mock_data.js
View file @
3537786f
...
@@ -80,13 +80,13 @@ export const inheritedMember = { ...member, isDirectMember: false };
...
@@ -80,13 +80,13 @@ export const inheritedMember = { ...member, isDirectMember: false };
export
const
member2faEnabled
=
{
...
member
,
user
:
{
...
member
.
user
,
twoFactorEnabled
:
true
}
};
export
const
member2faEnabled
=
{
...
member
,
user
:
{
...
member
.
user
,
twoFactorEnabled
:
true
}
};
export
const
pagination
JsonString
=
JSON
.
stringify
(
{
export
const
pagination
Data
=
{
current_page
:
1
,
current_page
:
1
,
per_page
:
5
,
per_page
:
5
,
total_items
:
10
,
total_items
:
10
,
param_name
:
'
page
'
,
param_name
:
'
page
'
,
params
:
{
search_groups
:
null
},
params
:
{
search_groups
:
null
},
}
)
;
};
export
const
pagination
=
{
export
const
pagination
=
{
currentPage
:
1
,
currentPage
:
1
,
...
@@ -95,3 +95,12 @@ export const pagination = {
...
@@ -95,3 +95,12 @@ export const pagination = {
paramName
:
'
page
'
,
paramName
:
'
page
'
,
params
:
{
search_groups
:
null
},
params
:
{
search_groups
:
null
},
};
};
export
const
dataAttribute
=
JSON
.
stringify
({
members
,
pagination
:
paginationData
,
source_id
:
234
,
can_manage_members
:
true
,
member_path
:
'
/groups/foo-bar/-/group_members/:id
'
,
ldap_override_path
:
'
/groups/ldap-group/-/group_members/:id/override
'
,
});
spec/frontend/members/utils_spec.js
View file @
3537786f
...
@@ -20,10 +20,9 @@ import {
...
@@ -20,10 +20,9 @@ import {
member2faEnabled
,
member2faEnabled
,
group
,
group
,
invite
,
invite
,
membersJsonString
,
members
,
members
,
paginationJsonString
,
pagination
,
pagination
,
dataAttribute
,
}
from
'
./mock_data
'
;
}
from
'
./mock_data
'
;
const
IS_CURRENT_USER_ID
=
123
;
const
IS_CURRENT_USER_ID
=
123
;
...
@@ -260,23 +259,23 @@ describe('Members Utils', () => {
...
@@ -260,23 +259,23 @@ describe('Members Utils', () => {
beforeEach
(()
=>
{
beforeEach
(()
=>
{
el
=
document
.
createElement
(
'
div
'
);
el
=
document
.
createElement
(
'
div
'
);
el
.
setAttribute
(
'
data-members
'
,
membersJsonString
);
el
.
setAttribute
(
'
data-data
'
,
dataAttribute
);
el
.
setAttribute
(
'
data-pagination
'
,
paginationJsonString
);
el
.
setAttribute
(
'
data-source-id
'
,
'
234
'
);
el
.
setAttribute
(
'
data-can-manage-members
'
,
'
true
'
);
});
});
afterEach
(()
=>
{
afterEach
(()
=>
{
el
=
null
;
el
=
null
;
});
});
it
(
'
correctly parses the data attributes
'
,
()
=>
{
it
(
'
correctly parses the data attribute
'
,
()
=>
{
expect
(
parseDataAttributes
(
el
)).
toEqual
({
expect
(
parseDataAttributes
(
el
)).
toEqual
(
expect
.
objectContaining
({
members
,
members
,
pagination
,
pagination
,
sourceId
:
234
,
sourceId
:
234
,
canManageMembers
:
true
,
canManageMembers
:
true
,
});
memberPath
:
'
/groups/foo-bar/-/group_members/:id
'
,
}),
);
});
});
});
});
...
...
spec/helpers/groups/group_members_helper_spec.rb
View file @
3537786f
...
@@ -23,20 +23,20 @@ RSpec.describe Groups::GroupMembersHelper do
...
@@ -23,20 +23,20 @@ RSpec.describe Groups::GroupMembersHelper do
end
end
end
end
describe
'#group_group_links_
data_json
'
do
describe
'#group_group_links_
serialized
'
do
include_context
'group_group_link'
include_context
'group_group_link'
it
'matches json schema'
do
it
'matches json schema'
do
json
=
helper
.
group_group_links_data_json
(
shared_group
.
shared_with_group_links
)
json
=
helper
.
send
(
:group_group_links_serialized
,
shared_group
.
shared_with_group_links
).
to_json
expect
(
json
).
to
match_schema
(
'group_link/group_group_links'
)
expect
(
json
).
to
match_schema
(
'group_link/group_group_links'
)
end
end
end
end
describe
'#
members_data_json
'
do
describe
'#
group_members_serialized
'
do
shared_examples
'members.json'
do
shared_examples
'members.json'
do
it
'matches json schema'
do
it
'matches json schema'
do
json
=
helper
.
members_data_json
(
group
,
present_members
([
group_member
]))
json
=
helper
.
send
(
:group_members_serialized
,
group
,
present_members
([
group_member
])).
to_json
expect
(
json
).
to
match_schema
(
'members'
)
expect
(
json
).
to
match_schema
(
'members'
)
end
end
...
@@ -69,76 +69,87 @@ RSpec.describe Groups::GroupMembersHelper do
...
@@ -69,76 +69,87 @@ RSpec.describe Groups::GroupMembersHelper do
end
end
end
end
describe
'#group_members_list_data_
attributes
'
do
describe
'#group_members_list_data_
json
'
do
let_it_be
(
:group_members
)
{
create_list
(
:group_member
,
2
,
group:
group
,
created_by:
current_user
)
}
let_it_be
(
:group_members
)
{
create_list
(
:group_member
,
2
,
group:
group
,
created_by:
current_user
)
}
let
(
:pagination
)
{
{}
}
let
(
:collection
)
{
group_members
}
let
(
:presented_members
)
{
present_members
(
collection
)
}
subject
{
Gitlab
::
Json
.
parse
(
helper
.
group_members_list_data_json
(
group
,
presented_members
,
pagination
))
}
before
do
before
do
allow
(
helper
).
to
receive
(
:group_group_member_path
).
with
(
group
,
':id'
).
and_return
(
'/groups/foo-bar/-/group_members/:id'
)
allow
(
helper
).
to
receive
(
:group_group_member_path
).
with
(
group
,
':id'
).
and_return
(
'/groups/foo-bar/-/group_members/:id'
)
allow
(
helper
).
to
receive
(
:can?
).
with
(
current_user
,
:admin_group_member
,
group
).
and_return
(
true
)
allow
(
helper
).
to
receive
(
:can?
).
with
(
current_user
,
:admin_group_member
,
group
).
and_return
(
true
)
end
end
it
'returns expected
hash
'
do
it
'returns expected
json
'
do
expect
(
helper
.
group_members_list_data_attributes
(
group
,
present_members
(
group_members
))).
to
include
(
{
expect
ed
=
{
members:
helper
.
members_data_json
(
group
,
present_members
(
group_members
)
),
members:
helper
.
send
(
:group_members_serialized
,
group
,
presented_members
),
member_path:
'/groups/foo-bar/-/group_members/:id'
,
member_path:
'/groups/foo-bar/-/group_members/:id'
,
source_id:
group
.
id
,
source_id:
group
.
id
,
can_manage_members:
'true'
can_manage_members:
true
})
}.
as_json
expect
(
subject
).
to
include
(
expected
)
end
end
context
'when pagination is not available'
do
context
'when pagination is not available'
do
it
'sets `pagination` attribute to expected json'
do
it
'sets `pagination` attribute to expected json'
do
expect
(
helper
.
group_members_list_data_attributes
(
group
,
present_members
(
group_members
))[
:pagination
]).
to
match
(
{
expect
ed
=
{
current_page:
nil
,
current_page:
nil
,
per_page:
nil
,
per_page:
nil
,
total_items:
2
,
total_items:
2
,
param_name:
nil
,
param_name:
nil
,
params:
{}
params:
{}
}.
to_json
)
}.
as_json
expect
(
subject
[
'pagination'
]).
to
include
(
expected
)
end
end
end
end
context
'when pagination is available'
do
context
'when pagination is available'
do
let
(
:collection
)
{
Kaminari
.
paginate_array
(
group_members
).
page
(
1
).
per
(
1
)
}
let
(
:collection
)
{
Kaminari
.
paginate_array
(
group_members
).
page
(
1
).
per
(
1
)
}
let
(
:pagination
)
{
{
param_name: :page
,
params:
{
search_groups:
nil
}
}
}
it
'sets `pagination` attribute to expected json'
do
it
'sets `pagination` attribute to expected json'
do
expect
(
expected
=
{
helper
.
group_members_list_data_attributes
(
group
,
present_members
(
collection
),
{
param_name: :page
,
params:
{
search_groups:
nil
}
}
)[
:pagination
]
).
to
match
({
current_page:
1
,
current_page:
1
,
per_page:
1
,
per_page:
1
,
total_items:
2
,
total_items:
2
,
param_name: :page
,
param_name: :page
,
params:
{
search_groups:
nil
}
params:
{
search_groups:
nil
}
}.
to_json
)
}.
as_json
expect
(
subject
[
'pagination'
]).
to
include
(
expected
)
end
end
end
end
end
end
describe
'#group_group_links_list_data_
attributes
'
do
describe
'#group_group_links_list_data_
json
'
do
include_context
'group_group_link'
include_context
'group_group_link'
subject
{
Gitlab
::
Json
.
parse
(
helper
.
group_group_links_list_data_json
(
shared_group
))
}
before
do
before
do
allow
(
helper
).
to
receive
(
:group_group_link_path
).
with
(
shared_group
,
':id'
).
and_return
(
'/groups/foo-bar/-/group_links/:id'
)
allow
(
helper
).
to
receive
(
:group_group_link_path
).
with
(
shared_group
,
':id'
).
and_return
(
'/groups/foo-bar/-/group_links/:id'
)
end
end
it
'returns expected
hash
'
do
it
'returns expected
json
'
do
expect
(
helper
.
group_group_links_list_data_attributes
(
shared_group
)).
to
include
(
{
expect
ed
=
{
pagination:
{
pagination:
{
current_page:
nil
,
current_page:
nil
,
per_page:
nil
,
per_page:
nil
,
total_items:
1
,
total_items:
1
,
param_name:
nil
,
param_name:
nil
,
params:
{}
params:
{}
}
.
to_json
,
},
members:
helper
.
group_group_links_data_json
(
shared_group
.
shared_with_group_links
),
members:
helper
.
send
(
:group_group_links_serialized
,
shared_group
.
shared_with_group_links
),
member_path:
'/groups/foo-bar/-/group_links/:id'
,
member_path:
'/groups/foo-bar/-/group_links/:id'
,
source_id:
shared_group
.
id
source_id:
shared_group
.
id
})
}.
as_json
expect
(
subject
).
to
include
(
expected
)
end
end
end
end
end
end
spec/helpers/projects/project_members_helper_spec.rb
View file @
3537786f
...
@@ -149,57 +149,64 @@ RSpec.describe Projects::ProjectMembersHelper do
...
@@ -149,57 +149,64 @@ RSpec.describe Projects::ProjectMembersHelper do
describe
'project members'
do
describe
'project members'
do
let_it_be
(
:project_members
)
{
create_list
(
:project_member
,
2
,
project:
project
)
}
let_it_be
(
:project_members
)
{
create_list
(
:project_member
,
2
,
project:
project
)
}
describe
'#project_members_data_json'
do
let
(
:collection
)
{
project_members
}
let
(
:presented_members
)
{
present_members
(
collection
)
}
describe
'#project_members_serialized'
do
it
'matches json schema'
do
it
'matches json schema'
do
expect
(
helper
.
project_members_data_json
(
project
,
present_members
(
project_members
))
).
to
match_schema
(
'members'
)
expect
(
helper
.
send
(
:project_members_serialized
,
project
,
presented_members
).
to_json
).
to
match_schema
(
'members'
)
end
end
end
end
describe
'#project_members_list_data_
attributes
'
do
describe
'#project_members_list_data_
json
'
do
let
(
:allow_admin_project
)
{
true
}
let
(
:allow_admin_project
)
{
true
}
let
(
:pagination
)
{
{}
}
subject
{
Gitlab
::
Json
.
parse
(
helper
.
project_members_list_data_json
(
project
,
presented_members
,
pagination
))
}
before
do
before
do
allow
(
helper
).
to
receive
(
:project_project_member_path
).
with
(
project
,
':id'
).
and_return
(
'/foo-bar/-/project_members/:id'
)
allow
(
helper
).
to
receive
(
:project_project_member_path
).
with
(
project
,
':id'
).
and_return
(
'/foo-bar/-/project_members/:id'
)
end
end
it
'returns expected
hash
'
do
it
'returns expected
json
'
do
expect
(
helper
.
project_members_list_data_attributes
(
project
,
present_members
(
project_members
))).
to
include
(
{
expect
ed
=
{
members:
helper
.
project_members_data_json
(
project
,
present_members
(
project_members
)
),
members:
helper
.
send
(
:project_members_serialized
,
project
,
presented_members
),
member_path:
'/foo-bar/-/project_members/:id'
,
member_path:
'/foo-bar/-/project_members/:id'
,
source_id:
project
.
id
,
source_id:
project
.
id
,
can_manage_members:
'true'
can_manage_members:
true
})
}.
as_json
expect
(
subject
).
to
include
(
expected
)
end
end
context
'when pagination is not available'
do
context
'when pagination is not available'
do
it
'sets `pagination` attribute to expected json'
do
it
'sets `pagination` attribute to expected json'
do
expect
(
helper
.
project_members_list_data_attributes
(
project
,
present_members
(
project_members
))[
:pagination
]).
to
match
(
{
expect
ed
=
{
current_page:
nil
,
current_page:
nil
,
per_page:
nil
,
per_page:
nil
,
total_items:
2
,
total_items:
2
,
param_name:
nil
,
param_name:
nil
,
params:
{}
params:
{}
}.
to_json
)
}.
as_json
expect
(
subject
[
'pagination'
]).
to
include
(
expected
)
end
end
end
end
context
'when pagination is available'
do
context
'when pagination is available'
do
let
(
:collection
)
{
Kaminari
.
paginate_array
(
project_members
).
page
(
1
).
per
(
1
)
}
let
(
:collection
)
{
Kaminari
.
paginate_array
(
project_members
).
page
(
1
).
per
(
1
)
}
let
(
:pagination
)
{
{
param_name: :page
,
params:
{
search_groups:
nil
}
}
}
it
'sets `pagination` attribute to expected json'
do
it
'sets `pagination` attribute to expected json'
do
expect
(
expected
=
{
helper
.
project_members_list_data_attributes
(
project
,
present_members
(
collection
),
{
param_name: :page
,
params:
{
search_groups:
nil
}
}
)[
:pagination
]
).
to
match
({
current_page:
1
,
current_page:
1
,
per_page:
1
,
per_page:
1
,
total_items:
2
,
total_items:
2
,
param_name: :page
,
param_name: :page
,
params:
{
search_groups:
nil
}
params:
{
search_groups:
nil
}
}.
to_json
)
}.
as_json
expect
(
subject
[
'pagination'
]).
to
match
(
expected
)
end
end
end
end
end
end
...
@@ -212,30 +219,34 @@ RSpec.describe Projects::ProjectMembersHelper do
...
@@ -212,30 +219,34 @@ RSpec.describe Projects::ProjectMembersHelper do
describe
'#project_group_links_data_json'
do
describe
'#project_group_links_data_json'
do
it
'matches json schema'
do
it
'matches json schema'
do
expect
(
helper
.
project_group_links_data_json
(
project_group_links
)
).
to
match_schema
(
'group_link/project_group_links'
)
expect
(
helper
.
send
(
:project_group_links_serialized
,
project_group_links
).
to_json
).
to
match_schema
(
'group_link/project_group_links'
)
end
end
end
end
describe
'#project_group_links_list_data_attributes'
do
describe
'#project_group_links_list_data_json'
do
subject
{
Gitlab
::
Json
.
parse
(
helper
.
project_group_links_list_data_json
(
project
,
project_group_links
))
}
before
do
before
do
allow
(
helper
).
to
receive
(
:project_group_link_path
).
with
(
project
,
':id'
).
and_return
(
'/foo-bar/-/group_links/:id'
)
allow
(
helper
).
to
receive
(
:project_group_link_path
).
with
(
project
,
':id'
).
and_return
(
'/foo-bar/-/group_links/:id'
)
allow
(
helper
).
to
receive
(
:can?
).
with
(
current_user
,
:admin_project_member
,
project
).
and_return
(
true
)
allow
(
helper
).
to
receive
(
:can?
).
with
(
current_user
,
:admin_project_member
,
project
).
and_return
(
true
)
end
end
it
'returns expected
hash
'
do
it
'returns expected
json
'
do
expect
(
helper
.
project_group_links_list_data_attributes
(
project
,
project_group_links
)).
to
include
(
{
expect
ed
=
{
members:
helper
.
project_group_links_data_json
(
project_group_links
),
members:
helper
.
send
(
:project_group_links_serialized
,
project_group_links
),
pagination:
{
pagination:
{
current_page:
nil
,
current_page:
nil
,
per_page:
nil
,
per_page:
nil
,
total_items:
1
,
total_items:
1
,
param_name:
nil
,
param_name:
nil
,
params:
{}
params:
{}
}
.
to_json
,
},
member_path:
'/foo-bar/-/group_links/:id'
,
member_path:
'/foo-bar/-/group_links/:id'
,
source_id:
project
.
id
,
source_id:
project
.
id
,
can_manage_members:
'true'
can_manage_members:
true
})
}.
as_json
expect
(
subject
).
to
include
(
expected
)
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