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
721e1709
Commit
721e1709
authored
Jul 13, 2020
by
Dallas Reedy
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Refactor to better adhere to SRP
parent
e44fbd33
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
108 additions
and
95 deletions
+108
-95
ee/app/helpers/ee/trial_helper.rb
ee/app/helpers/ee/trial_helper.rb
+13
-10
ee/spec/helpers/ee/trial_helper_spec.rb
ee/spec/helpers/ee/trial_helper_spec.rb
+95
-85
No files found.
ee/app/helpers/ee/trial_helper.rb
View file @
721e1709
...
@@ -14,23 +14,26 @@ module EE
...
@@ -14,23 +14,26 @@ module EE
end
end
def
namespace_options_for_select
(
selected
=
nil
)
def
namespace_options_for_select
(
selected
=
nil
)
groups
=
current_user
.
manageable_groups_eligible_for_trial
.
map
{
|
g
|
[
g
.
name
,
g
.
id
]
}
user_namespace
=
current_user
.
namespace
users
=
if
user_namespace
.
gitlab_subscription
&
.
trial?
[]
else
[[
user_namespace
.
name
,
user_namespace
.
id
]]
end
grouped_options
=
{
grouped_options
=
{
'New'
=>
[[
_
(
'Create group'
),
0
]],
'New'
=>
[[
_
(
'Create group'
),
0
]],
'Groups'
=>
groups
,
'Groups'
=>
trial_
groups
,
'Users'
=>
users
'Users'
=>
trial_
users
}
}
grouped_options_for_select
(
grouped_options
,
selected
,
prompt:
_
(
'Please select'
))
grouped_options_for_select
(
grouped_options
,
selected
,
prompt:
_
(
'Please select'
))
end
end
def
trial_users
user_namespace
=
current_user
.
namespace
return
[]
if
user_namespace
.
gitlab_subscription
&
.
trial?
[[
user_namespace
.
name
,
user_namespace
.
id
]]
end
def
trial_groups
current_user
.
manageable_groups_eligible_for_trial
.
map
{
|
g
|
[
g
.
name
,
g
.
id
]
}
end
def
show_trial_errors?
(
namespace
,
service_result
)
def
show_trial_errors?
(
namespace
,
service_result
)
namespace
&
.
invalid?
||
(
service_result
&&
!
service_result
[
:success
])
namespace
&
.
invalid?
||
(
service_result
&&
!
service_result
[
:success
])
end
end
...
...
ee/spec/helpers/ee/trial_helper_spec.rb
View file @
721e1709
...
@@ -7,142 +7,152 @@ RSpec.describe EE::TrialHelper do
...
@@ -7,142 +7,152 @@ RSpec.describe EE::TrialHelper do
describe
'#namespace_options_for_select'
do
describe
'#namespace_options_for_select'
do
let_it_be
(
:user
)
{
create
:user
}
let_it_be
(
:user
)
{
create
:user
}
let_it_be
(
:group1
)
{
create
:group
}
let_it_be
(
:group2
)
{
create
:group
}
let
(
:expected_prompt_option
)
{
'Please select'
}
let
(
:expected_new_options
)
{
[[
'Create group'
,
0
]]
}
let
(
:expected_group_options
)
{
[]
}
let
(
:expected_group_options
)
{
[]
}
let
(
:expected_user_options
)
{
[[
user
.
namespace
.
name
,
user
.
namespace
.
id
]]
}
let
(
:expected_user_options
)
{
[[
user
.
namespace
.
name
,
user
.
namespace
.
id
]]
}
let
(
:generated_html
)
do
let
(
:generated_html
)
do
grouped_options_for_select
({
grouped_options_for_select
({
'New'
=>
expected_new_options
,
'New'
=>
[[
'Create group'
,
0
]]
,
'Groups'
=>
expected_group_options
,
'Groups'
=>
expected_group_options
,
'Users'
=>
expected_user_options
'Users'
=>
expected_user_options
},
nil
,
prompt:
expected_prompt_option
)
},
nil
,
prompt:
'Please select'
)
end
end
before
do
before
do
user
.
reload
# necessary to cache-bust the user.namespace.gitlab_subscription object
allow
(
helper
).
to
receive
(
:trial_groups
).
and_return
(
expected_group_options
)
allow
(
helper
).
to
receive
(
:
current_user
).
and_return
(
user
)
allow
(
helper
).
to
receive
(
:
trial_users
).
and_return
(
expected_user_options
)
end
end
subject
{
helper
.
namespace_options_for_select
}
subject
{
helper
.
namespace_options_for_select
}
context
'when
a user owns no groups beyond their personal namespace
'
do
context
'when
the user’s namespace can be trialed
'
do
it
'shows “Create group” & user namespace options
'
do
context
'and the user has no groups or none of their groups can be trialed
'
do
expect
(
subject
).
to
eq
(
generated_html
)
it
{
is_expected
.
to
eq
(
generated_html
)
}
end
end
context
'when they have already trialed their personal namespace'
do
context
'and the user has some groups which can be trialed'
do
before
do
let
(
:expected_group_options
)
{
[
group1
,
group2
].
map
{
|
g
|
[
g
.
name
,
g
.
id
]}
}
create
:gitlab_subscription
,
namespace:
user
.
namespace
,
trial:
true
it
{
is_expected
.
to
eq
(
generated_html
)
}
end
end
end
context
'when the user’s namespace has already been trialed'
do
let
(
:expected_user_options
)
{
[]
}
let
(
:expected_user_options
)
{
[]
}
it
'only shows “Create group” option'
do
context
'and the user has no groups or none of their groups can be trialed'
do
expect
(
subject
).
to
eq
(
generated_html
)
it
{
is_expected
.
to
eq
(
generated_html
)
}
end
context
'and the user has some groups which can be trialed'
do
let
(
:expected_group_options
)
{
[
group1
,
group2
].
map
{
|
g
|
[
g
.
name
,
g
.
id
]}
}
it
{
is_expected
.
to
eq
(
generated_html
)
}
end
end
end
end
end
end
context
'when a user is an owner of a group beyond their personal namespace'
do
describe
'#trial_users'
do
let_it_be
(
:group
)
{
create
:group
}
let_it_be
(
:user
)
{
create
:user
}
let
(
:user_eligible_for_trial_result
)
{
[[
user
.
namespace
.
name
,
user
.
namespace
.
id
]]
}
let
(
:user_ineligible_for_trial_result
)
{
[]
}
before
do
before
do
group
.
add_owner
(
user
)
user
.
reload
# necessary to cache-bust the user.namespace.gitlab_subscription object
allow
(
helper
).
to
receive
(
:current_user
).
and_return
(
user
)
end
end
context
'when the group is eligible for a trial'
do
subject
{
helper
.
trial_users
}
let
(
:expected_group_options
)
{
[[
group
.
name
,
group
.
id
]]
}
it
'shows options for “Create group,” for the group namespace, & for their user namespace'
do
context
'when the user has no subscription on their namespace'
do
expect
(
subject
).
to
eq
(
generated_html
)
it
{
is_expected
.
to
eq
(
user_eligible_for_trial_result
)
}
end
end
end
context
'when they have already trialed the group'
do
context
'when the user has a subscription on their namespace'
do
before
do
let
(
:trialed
)
{
false
}
create
:gitlab_subscription
,
namespace:
group
,
trial:
true
let!
(
:subscription
)
{
create
:gitlab_subscription
,
namespace:
user
.
namespace
,
trial:
trialed
}
end
it
'shows options for “Create group” & their user namespace, but not for the group'
do
context
'and the user has not yet trialed their namespace'
do
expect
(
subject
).
to
eq
(
generated_html
)
it
{
is_expected
.
to
eq
(
user_eligible_for_trial_result
)
}
end
end
end
context
'when they have already trialed their personal namespace'
do
context
'and the user has already trialed their namespace'
do
before
do
let
(
:trialed
)
{
true
}
create
:gitlab_subscription
,
namespace:
user
.
namespace
,
trial:
true
end
let
(
:expected_group_options
)
{
[[
group
.
name
,
group
.
id
]]
}
it
{
is_expected
.
to
eq
(
user_ineligible_for_trial_result
)
}
let
(
:expected_user_options
)
{
[]
}
end
it
'shows options for “Create group” & the group namespace, but not their user namespace'
do
expect
(
subject
).
to
eq
(
generated_html
)
end
end
end
end
context
'when they have already trialed the group & their personal namespace'
do
describe
'#trial_groups'
do
let_it_be
(
:user
)
{
create
:user
}
let
(
:no_groups
)
{
[]
}
before
do
before
do
create
:gitlab_subscription
,
namespace:
user
.
namespace
,
trial:
true
allow
(
helper
).
to
receive
(
:current_user
).
and_return
(
user
)
create
:gitlab_subscription
,
namespace:
group
,
trial:
true
end
end
let
(
:expected_user_options
)
{
[]
}
subject
{
helper
.
trial_groups
}
it
'only shows the “Create group” option'
do
context
'when the user is not an owner/maintainer of any groups'
do
expect
(
subject
).
to
eq
(
generated_html
)
it
{
is_expected
.
to
eq
(
no_groups
)
}
end
end
end
end
context
'when
a user is an owner or maintainer of several namespace
s'
do
context
'when
the user is an owner/maintainer of some group
s'
do
let_it_be
(
:group1
)
{
create
:group
,
name:
'Group 1'
}
let_it_be
(
:group1
)
{
create
:group
,
name:
'Group 1'
}
let_it_be
(
:subgroup
)
{
create
:group
,
parent:
group1
,
name:
'Sub-Group 1'
}
let_it_be
(
:subgroup
1
)
{
create
:group
,
parent:
group1
,
name:
'Sub-Group 1'
}
let_it_be
(
:group2
)
{
create
:group
,
name:
'Group 2'
}
let_it_be
(
:group2
)
{
create
:group
,
name:
'Group 2'
}
let_it_be
(
:subgroup2
)
{
create
:group
,
parent:
group2
,
name:
'Sub-Group 2'
}
let_it_be
(
:subgroup2
)
{
create
:group
,
parent:
group2
,
name:
'Sub-Group 2'
}
let_it_be
(
:subsubgroup
)
{
create
:group
,
parent:
subgroup2
,
name:
'Sub-Sub-Group 1'
}
let_it_be
(
:subsubgroup1
)
{
create
:group
,
parent:
subgroup2
,
name:
'Sub-Sub-Group 1'
}
let
(
:all_groups
)
{
[
group1
,
group2
,
subgroup1
,
subgroup2
,
subsubgroup1
].
map
{
|
g
|
[
g
.
name
,
g
.
id
]
}
}
before
do
before
do
group1
.
add_owner
(
user
)
group1
.
add_owner
(
user
)
group2
.
add_maintainer
(
user
)
group2
.
add_maintainer
(
user
)
end
end
context
'when each namespace is eligible for a trial'
do
context
'and none of the groups have subscriptions'
do
let
(
:expected_group_options
)
do
it
{
is_expected
.
to
eq
(
all_groups
)
}
[
[
group1
.
name
,
group1
.
id
],
[
group2
.
name
,
group2
.
id
],
[
subgroup
.
name
,
subgroup
.
id
],
[
subgroup2
.
name
,
subgroup2
.
id
],
[
subsubgroup
.
name
,
subsubgroup
.
id
]
]
end
end
it
'shows options for “Create group,” for each group namespace, & for their user namespace'
do
context
'and the groups have subscriptions'
do
expect
(
subject
).
to
eq
(
generated_html
)
let
(
:trialed_group1
)
{
false
}
end
let
(
:trialed_subgroup1
)
{
false
}
end
let
(
:trialed_group2
)
{
false
}
let
(
:trialed_subgroup2
)
{
false
}
let
(
:trialed_subsubgroup1
)
{
false
}
context
'when they have already trialed for their user & some of the groups'
do
let!
(
:subscription_group1
)
{
create
:gitlab_subscription
,
namespace:
group1
,
trial:
trialed_group1
}
before
do
let!
(
:subscription_subgroup1
)
{
create
:gitlab_subscription
,
namespace:
subgroup1
,
trial:
trialed_subgroup1
}
create
:gitlab_subscription
,
namespace:
user
.
namespace
,
trial:
true
let!
(
:subscription_group2
)
{
create
:gitlab_subscription
,
namespace:
group2
,
trial:
trialed_group2
}
create
:gitlab_subscription
,
namespace:
group1
,
trial:
true
let!
(
:subscription_subgroup2
)
{
create
:gitlab_subscription
,
namespace:
subgroup2
,
trial:
trialed_subgroup2
}
create
:gitlab_subscription
,
namespace:
group2
,
trial:
true
let!
(
:subscription_subsubgroup1
)
{
create
:gitlab_subscription
,
namespace:
subsubgroup1
,
trial:
trialed_subsubgroup1
}
create
:gitlab_subscription
,
namespace:
subgroup
,
trial:
true
context
'and none of the groups have been trialed yet'
do
it
{
is_expected
.
to
eq
(
all_groups
)
}
end
end
let
(
:expected_group_options
)
do
context
'and some of the groups have been trialed'
do
[
let
(
:trialed_group1
)
{
true
}
[
subgroup2
.
name
,
subgroup2
.
id
],
let
(
:trialed_subgroup1
)
{
true
}
[
subsubgroup
.
name
,
subsubgroup
.
id
]
let
(
:trialed_subgroup2
)
{
true
}
]
let
(
:some_groups
)
{
[
group2
,
subsubgroup1
].
map
{
|
g
|
[
g
.
name
,
g
.
id
]}
}
it
{
is_expected
.
to
eq
(
some_groups
)
}
end
end
let
(
:expected_user_options
)
{
[]
}
it
'only shows options for “Create group” & for the non-trialed groups'
do
context
'and all of the groups have already been trialed'
do
expect
(
subject
).
to
eq
(
generated_html
)
let
(
:trialed_group1
)
{
true
}
let
(
:trialed_subgroup1
)
{
true
}
let
(
:trialed_group2
)
{
true
}
let
(
:trialed_subgroup2
)
{
true
}
let
(
:trialed_subsubgroup1
)
{
true
}
it
{
is_expected
.
to
eq
(
no_groups
)
}
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