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
704524b1
Commit
704524b1
authored
Oct 20, 2021
by
Angelo Gulina
Committed by
Michael Kozono
Oct 20, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Retrieve the account id and pass it to the FE
parent
ab94e94d
Changes
11
Hide whitespace changes
Inline
Side-by-side
Showing
11 changed files
with
120 additions
and
65 deletions
+120
-65
ee/app/controllers/subscriptions_controller.rb
ee/app/controllers/subscriptions_controller.rb
+30
-9
ee/app/helpers/subscriptions_helper.rb
ee/app/helpers/subscriptions_helper.rb
+4
-4
ee/app/services/gitlab_subscriptions/fetch_purchase_eligible_namespaces_service.rb
...bscriptions/fetch_purchase_eligible_namespaces_service.rb
+10
-5
ee/app/views/subscriptions/buy_minutes.html.haml
ee/app/views/subscriptions/buy_minutes.html.haml
+1
-1
ee/app/views/subscriptions/buy_storage.html.haml
ee/app/views/subscriptions/buy_storage.html.haml
+1
-1
ee/app/views/subscriptions/new.html.haml
ee/app/views/subscriptions/new.html.haml
+0
-1
ee/lib/gitlab/subscription_portal/clients/graphql.rb
ee/lib/gitlab/subscription_portal/clients/graphql.rb
+1
-0
ee/spec/controllers/subscriptions_controller_spec.rb
ee/spec/controllers/subscriptions_controller_spec.rb
+41
-34
ee/spec/helpers/subscriptions_helper_spec.rb
ee/spec/helpers/subscriptions_helper_spec.rb
+3
-2
ee/spec/lib/gitlab/subscription_portal/clients/graphql_spec.rb
...ec/lib/gitlab/subscription_portal/clients/graphql_spec.rb
+4
-1
ee/spec/services/gitlab_subscriptions/fetch_purchase_eligible_namespaces_service_spec.rb
...ptions/fetch_purchase_eligible_namespaces_service_spec.rb
+25
-7
No files found.
ee/app/controllers/subscriptions_controller.rb
View file @
704524b1
...
@@ -34,7 +34,12 @@ class SubscriptionsController < ApplicationController
...
@@ -34,7 +34,12 @@ class SubscriptionsController < ApplicationController
def
buy_minutes
def
buy_minutes
return
render_404
unless
ci_minutes_plan_data
.
present?
return
render_404
unless
ci_minutes_plan_data
.
present?
@group
=
find_group
(
plan_id:
ci_minutes_plan_data
[
"id"
])
# At the moment of this comment the account id is directly available to the view.
# This might change in the future given the intention to associate the account id to the namespace.
# See: https://gitlab.com/gitlab-org/gitlab/-/issues/338546#note_684762160
result
=
find_group
(
plan_id:
ci_minutes_plan_data
[
"id"
])
@group
=
result
[
:namespace
]
@account_id
=
result
[
:account_id
]
return
render_404
if
@group
.
nil?
return
render_404
if
@group
.
nil?
...
@@ -44,7 +49,12 @@ class SubscriptionsController < ApplicationController
...
@@ -44,7 +49,12 @@ class SubscriptionsController < ApplicationController
def
buy_storage
def
buy_storage
return
render_404
unless
storage_plan_data
.
present?
return
render_404
unless
storage_plan_data
.
present?
@group
=
find_group
(
plan_id:
storage_plan_data
[
"id"
])
# At the moment of this comment the account id is directly available to the view.
# This might change in the future given the intention to associate the account id to the namespace.
# See: https://gitlab.com/gitlab-org/gitlab/-/issues/338546#note_684762160
result
=
find_group
(
plan_id:
storage_plan_data
[
"id"
])
@group
=
result
[
:namespace
]
@account_id
=
result
[
:account_id
]
return
render_404
if
@group
.
nil?
return
render_404
if
@group
.
nil?
...
@@ -63,7 +73,7 @@ class SubscriptionsController < ApplicationController
...
@@ -63,7 +73,7 @@ class SubscriptionsController < ApplicationController
def
create
def
create
current_user
.
update
(
setup_for_company:
true
)
if
params
[
:setup_for_company
]
current_user
.
update
(
setup_for_company:
true
)
if
params
[
:setup_for_company
]
group
=
params
[
:selected_group
]
?
find_group
(
plan_id:
subscription_params
[
:plan_id
])
:
create_group
group
=
params
[
:selected_group
]
?
current_group
:
create_group
return
not_found
if
group
.
nil?
return
not_found
if
group
.
nil?
return
render
json:
group
.
errors
.
to_json
unless
group
.
persisted?
return
render
json:
group
.
errors
.
to_json
unless
group
.
persisted?
...
@@ -105,11 +115,17 @@ class SubscriptionsController < ApplicationController
...
@@ -105,11 +115,17 @@ class SubscriptionsController < ApplicationController
def
find_group
(
plan_id
:)
def
find_group
(
plan_id
:)
selected_group
=
current_user
.
manageable_groups
.
top_most
.
find
(
params
[
:selected_group
])
selected_group
=
current_user
.
manageable_groups
.
top_most
.
find
(
params
[
:selected_group
])
result
=
GitlabSubscriptions
::
F
ilter
PurchaseEligibleNamespacesService
result
=
GitlabSubscriptions
::
F
etch
PurchaseEligibleNamespacesService
.
new
(
user:
current_user
,
plan_id:
plan_id
,
namespaces:
Array
(
selected_group
))
.
new
(
user:
current_user
,
plan_id:
plan_id
,
namespaces:
Array
(
selected_group
))
.
execute
.
execute
result
.
success?
?
result
.
payload
.
first
:
nil
return
{}
unless
result
.
success?
result
.
payload
.
first
||
{}
end
def
current_group
find_group
(
plan_id:
subscription_params
[
:plan_id
]).
dig
(
:namespace
)
end
end
def
create_group
def
create_group
...
@@ -149,12 +165,17 @@ class SubscriptionsController < ApplicationController
...
@@ -149,12 +165,17 @@ class SubscriptionsController < ApplicationController
def
load_eligible_groups
def
load_eligible_groups
return
@eligible_groups
=
[]
unless
current_user
return
@eligible_groups
=
[]
unless
current_user
@eligible_groups
=
fetch_eligible_groups
end
def
fetch_eligible_groups
candidate_groups
=
current_user
.
manageable_groups
.
top_most
.
with_counts
(
archived:
false
)
candidate_groups
=
current_user
.
manageable_groups
.
top_most
.
with_counts
(
archived:
false
)
result
=
GitlabSubscriptions
::
FetchPurchaseEligibleNamespacesService
.
new
(
user:
current_user
,
namespaces:
candidate_groups
,
any_self_service_plan:
true
)
.
execute
result
=
GitlabSubscriptions
::
FilterPurchaseEligibleNamespacesService
return
[]
unless
result
.
success?
.
new
(
user:
current_user
,
namespaces:
candidate_groups
,
any_self_service_plan:
true
)
.
execute
@eligible_groups
=
result
.
success?
?
result
.
payload
:
[]
(
result
.
payload
||
[]).
map
{
|
h
|
h
.
dig
(
:namespace
)
}
end
end
end
end
ee/app/helpers/subscriptions_helper.rb
View file @
704524b1
...
@@ -16,9 +16,9 @@ module SubscriptionsHelper
...
@@ -16,9 +16,9 @@ module SubscriptionsHelper
}
}
end
end
def
buy_addon_data
(
group
,
anchor
,
purchased_product
)
def
buy_addon_data
(
group
,
a
ccount_id
,
a
nchor
,
purchased_product
)
{
{
group_data:
[
present_group
(
group
)].
to_json
,
group_data:
[
present_group
(
group
,
account_id
)].
to_json
,
namespace_id:
params
[
:selected_group
],
namespace_id:
params
[
:selected_group
],
redirect_after_success:
group_usage_quotas_path
(
group
,
anchor:
anchor
,
purchased_product:
purchased_product
),
redirect_after_success:
group_usage_quotas_path
(
group
,
anchor:
anchor
,
purchased_product:
purchased_product
),
source:
params
[
:source
]
source:
params
[
:source
]
...
@@ -57,10 +57,10 @@ module SubscriptionsHelper
...
@@ -57,10 +57,10 @@ module SubscriptionsHelper
groups
.
map
{
|
namespace
|
present_group
(
namespace
)
}
groups
.
map
{
|
namespace
|
present_group
(
namespace
)
}
end
end
def
present_group
(
namespace
)
def
present_group
(
namespace
,
account_id
=
nil
)
{
{
id:
namespace
.
id
,
id:
namespace
.
id
,
account_id:
nil
,
account_id:
account_id
,
name:
namespace
.
name
,
name:
namespace
.
name
,
users:
namespace
.
member_count
,
users:
namespace
.
member_count
,
guests:
namespace
.
guest_count
guests:
namespace
.
guest_count
...
...
ee/app/services/gitlab_subscriptions/f
ilter
_purchase_eligible_namespaces_service.rb
→
ee/app/services/gitlab_subscriptions/f
etch
_purchase_eligible_namespaces_service.rb
View file @
704524b1
# frozen_string_literal: true
# frozen_string_literal: true
# F
ilter a list of namespaces by their eligibility to purchase a new plan.
# F
etch a list of namespaces and filter them by their eligibility to purchase a new subscription
#
#
# - When `plan_id: ID` is supplied the eligibility will be checked for that specific plan ID.
# - When `plan_id: ID` is supplied the eligibility will be checked for that specific plan ID.
# This param should be supplied when checking add on pack eligibility.
# This param should be supplied when checking add on pack eligibility.
# - When `any_self_service_plan: Boolean` is supplied, the eligibility to have a new self-service plan
# - When `any_self_service_plan: Boolean` is supplied, the eligibility to have a new self-service plan
# (ie Premium/Ultimate) in general is checked.
# (ie Premium/Ultimate) in general is checked.
# - When present, the account id associated with the namespace will be added.
# This is needed in the context of add on purchase, in order to correctly initialise the payment form.
module
GitlabSubscriptions
module
GitlabSubscriptions
class
F
ilter
PurchaseEligibleNamespacesService
class
F
etch
PurchaseEligibleNamespacesService
include
::
Gitlab
::
Utils
::
StrongMemoize
include
::
Gitlab
::
Utils
::
StrongMemoize
def
initialize
(
user
:,
namespaces
:,
plan_id:
nil
,
any_self_service_plan:
nil
)
def
initialize
(
user
:,
namespaces
:,
plan_id:
nil
,
any_self_service_plan:
nil
)
...
@@ -23,9 +25,12 @@ module GitlabSubscriptions
...
@@ -23,9 +25,12 @@ module GitlabSubscriptions
return
missing_plan_error
if
plan_id
.
nil?
&&
any_self_service_plan
.
nil?
return
missing_plan_error
if
plan_id
.
nil?
&&
any_self_service_plan
.
nil?
if
response
[
:success
]
&&
response
[
:data
]
if
response
[
:success
]
&&
response
[
:data
]
eligible_ids
=
response
[
:data
].
map
{
|
data
|
data
[
'id'
]
}.
to_set
eligible_namespaces
=
response
[
:data
].
to_h
{
|
data
|
[
data
[
"id"
],
data
[
"accountId"
]]
}
data
=
namespaces
.
each_with_object
([])
do
|
namespace
,
acc
|
data
=
namespaces
.
filter
{
|
namespace
|
eligible_ids
.
include?
(
namespace
.
id
)
}
if
eligible_namespaces
.
include?
(
namespace
.
id
)
acc
<<
{
namespace:
namespace
,
account_id:
eligible_namespaces
[
namespace
.
id
]
}
end
end
success
(
data
)
success
(
data
)
else
else
...
...
ee/app/views/subscriptions/buy_minutes.html.haml
View file @
704524b1
-
page_title
_
(
'Buy CI Minutes'
)
-
page_title
_
(
'Buy CI Minutes'
)
#js-buy-minutes
{
data:
buy_addon_data
(
@group
,
'pipelines-quota-tab'
,
s_
(
'Checkout|CI minutes'
))
}
#js-buy-minutes
{
data:
buy_addon_data
(
@group
,
@account_id
,
'pipelines-quota-tab'
,
s_
(
'Checkout|CI minutes'
))
}
ee/app/views/subscriptions/buy_storage.html.haml
View file @
704524b1
-
page_title
_
(
'Buy Storage'
)
-
page_title
_
(
'Buy Storage'
)
#js-buy-storage
{
data:
buy_addon_data
(
@group
,
'storage-quota-tab'
,
s_
(
'Checkout|a storage subscription'
))
}
#js-buy-storage
{
data:
buy_addon_data
(
@group
,
@account_id
,
'storage-quota-tab'
,
s_
(
'Checkout|a storage subscription'
))
}
ee/app/views/subscriptions/new.html.haml
View file @
704524b1
-
page_title
_
(
'Checkout'
)
-
page_title
_
(
'Checkout'
)
#js-new-subscription
{
data:
subscription_data
(
@eligible_groups
)
}
#js-new-subscription
{
data:
subscription_data
(
@eligible_groups
)
}
ee/lib/gitlab/subscription_portal/clients/graphql.rb
View file @
704524b1
...
@@ -123,6 +123,7 @@ module Gitlab
...
@@ -123,6 +123,7 @@ module Gitlab
query FilterEligibleNamespaces($customerUid: Int!, $namespaces: [GitlabNamespaceInput!]!, $planId: ID, $eligibleForPurchase: Boolean) {
query FilterEligibleNamespaces($customerUid: Int!, $namespaces: [GitlabNamespaceInput!]!, $planId: ID, $eligibleForPurchase: Boolean) {
namespaceEligibility(customerUid: $customerUid, namespaces: $namespaces, planId: $planId, eligibleForPurchase: $eligibleForPurchase) {
namespaceEligibility(customerUid: $customerUid, namespaces: $namespaces, planId: $planId, eligibleForPurchase: $eligibleForPurchase) {
id
id
accountId: zuoraAccountId
}
}
}
}
GQL
GQL
...
...
ee/spec/controllers/subscriptions_controller_spec.rb
View file @
704524b1
...
@@ -40,12 +40,14 @@ RSpec.describe SubscriptionsController do
...
@@ -40,12 +40,14 @@ RSpec.describe SubscriptionsController do
group
.
add_owner
(
user
)
group
.
add_owner
(
user
)
allow_next_instance_of
(
allow_next_instance_of
(
GitlabSubscriptions
::
F
ilter
PurchaseEligibleNamespacesService
,
GitlabSubscriptions
::
F
etch
PurchaseEligibleNamespacesService
,
user:
user
,
user:
user
,
namespaces:
[
group
],
namespaces:
[
group
],
any_self_service_plan:
true
any_self_service_plan:
true
)
do
|
instance
|
)
do
|
instance
|
allow
(
instance
).
to
receive
(
:execute
).
and_return
(
instance_double
(
ServiceResponse
,
success?:
true
,
payload:
[
group
]))
allow
(
instance
).
to
receive
(
:execute
).
and_return
(
instance_double
(
ServiceResponse
,
success?:
true
,
payload:
[{
namespace:
group
,
account_id:
nil
}])
)
end
end
end
end
...
@@ -59,7 +61,7 @@ RSpec.describe SubscriptionsController do
...
@@ -59,7 +61,7 @@ RSpec.describe SubscriptionsController do
context
'when there are no eligible groups for the subscription'
do
context
'when there are no eligible groups for the subscription'
do
it
'assigns eligible groups as an empty array'
do
it
'assigns eligible groups as an empty array'
do
allow_next_instance_of
(
allow_next_instance_of
(
GitlabSubscriptions
::
F
ilter
PurchaseEligibleNamespacesService
,
GitlabSubscriptions
::
F
etch
PurchaseEligibleNamespacesService
,
user:
user
,
user:
user
,
namespaces:
[],
namespaces:
[],
any_self_service_plan:
true
any_self_service_plan:
true
...
@@ -77,6 +79,7 @@ RSpec.describe SubscriptionsController do
...
@@ -77,6 +79,7 @@ RSpec.describe SubscriptionsController do
describe
'GET #buy_minutes'
do
describe
'GET #buy_minutes'
do
let_it_be
(
:group
)
{
create
(
:group
)
}
let_it_be
(
:group
)
{
create
(
:group
)
}
let_it_be
(
:plan_id
)
{
'ci_minutes'
}
subject
(
:buy_minutes
)
{
get
:buy_minutes
,
params:
{
selected_group:
group
.
id
}
}
subject
(
:buy_minutes
)
{
get
:buy_minutes
,
params:
{
selected_group:
group
.
id
}
}
...
@@ -112,12 +115,14 @@ RSpec.describe SubscriptionsController do
...
@@ -112,12 +115,14 @@ RSpec.describe SubscriptionsController do
.
and_return
({
success:
true
,
data:
[{
'id'
=>
'ci_minutes'
}]
})
.
and_return
({
success:
true
,
data:
[{
'id'
=>
'ci_minutes'
}]
})
allow_next_instance_of
(
allow_next_instance_of
(
GitlabSubscriptions
::
F
ilter
PurchaseEligibleNamespacesService
,
GitlabSubscriptions
::
F
etch
PurchaseEligibleNamespacesService
,
user:
user
,
user:
user
,
plan_id:
'ci_minutes'
,
plan_id:
'ci_minutes'
,
namespaces:
[
group
]
namespaces:
[
group
]
)
do
|
instance
|
)
do
|
instance
|
allow
(
instance
).
to
receive
(
:execute
).
and_return
(
instance_double
(
ServiceResponse
,
success?:
true
,
payload:
[
group
]))
allow
(
instance
).
to
receive
(
:execute
).
and_return
(
instance_double
(
ServiceResponse
,
success?:
true
,
payload:
[{
namespace:
group
,
account_id:
nil
}])
)
end
end
end
end
...
@@ -128,28 +133,24 @@ RSpec.describe SubscriptionsController do
...
@@ -128,28 +133,24 @@ RSpec.describe SubscriptionsController do
buy_minutes
buy_minutes
expect
(
assigns
(
:group
)).
to
eq
group
expect
(
assigns
(
:group
)).
to
eq
group
expect
(
assigns
(
:account_id
)).
to
eq
nil
end
end
end
end
context
'with :new_route_ci_minutes_purchase disabled'
do
context
'with :new_route_ci_minutes_purchase disabled'
do
before
do
before
do
allow
(
Gitlab
::
SubscriptionPortal
::
Client
)
stub_feature_flags
(
new_route_ci_minutes_purchase:
false
)
.
to
receive
(
:get_plans
).
with
(
tags:
[
'CI_1000_MINUTES_PLAN'
])
end
.
and_return
({
success:
true
,
data:
[{
'id'
=>
'ci_minutes'
}]
})
stub_feature_flags
(
new_route_ci_minutes_purchase:
false
)
it
{
is_expected
.
to
have_gitlab_http_status
(
:not_found
)
}
sign_in
(
user
)
end
end
end
it
{
is_expected
.
to
have_gitlab_http_status
(
:not_found
)
}
end
end
end
end
describe
'GET #buy_storage'
do
describe
'GET #buy_storage'
do
let_it_be
(
:group
)
{
create
(
:group
)
}
let_it_be
(
:group
)
{
create
(
:group
)
}
subject
{
get
:buy_storage
,
params:
{
selected_group:
group
.
id
}
}
subject
(
:buy_storage
)
{
get
:buy_storage
,
params:
{
selected_group:
group
.
id
}
}
context
'with authenticated user'
do
context
'with authenticated user'
do
before
do
before
do
...
@@ -172,7 +173,7 @@ RSpec.describe SubscriptionsController do
...
@@ -172,7 +173,7 @@ RSpec.describe SubscriptionsController do
it
{
is_expected
.
to
have_gitlab_http_status
(
:not_found
)
}
it
{
is_expected
.
to
have_gitlab_http_status
(
:not_found
)
}
end
end
context
'w
ith :new_route_storage_purchase enabled
'
do
context
'w
hen there are groups eligible for the addon
'
do
let_it_be
(
:group
)
{
create
(
:group
)
}
let_it_be
(
:group
)
{
create
(
:group
)
}
before
do
before
do
...
@@ -183,31 +184,35 @@ RSpec.describe SubscriptionsController do
...
@@ -183,31 +184,35 @@ RSpec.describe SubscriptionsController do
.
and_return
({
success:
true
,
data:
[{
'id'
=>
'storage'
}]
})
.
and_return
({
success:
true
,
data:
[{
'id'
=>
'storage'
}]
})
allow_next_instance_of
(
allow_next_instance_of
(
GitlabSubscriptions
::
F
ilter
PurchaseEligibleNamespacesService
,
GitlabSubscriptions
::
F
etch
PurchaseEligibleNamespacesService
,
user:
user
,
user:
user
,
plan_id:
'storage'
,
plan_id:
'storage'
,
namespaces:
[
group
]
namespaces:
[
group
]
)
do
|
instance
|
)
do
|
instance
|
allow
(
instance
).
to
receive
(
:execute
).
and_return
(
instance_double
(
ServiceResponse
,
success?:
true
,
payload:
[
group
]))
allow
(
instance
).
to
receive
(
:execute
).
and_return
(
instance_double
(
ServiceResponse
,
success?:
true
,
payload:
[{
namespace:
group
,
account_id:
nil
}])
)
end
end
end
end
it
{
is_expected
.
to
render_template
'layouts/checkout'
}
it
{
is_expected
.
to
render_template
'layouts/checkout'
}
it
{
is_expected
.
to
render_template
:buy_storage
}
it
{
is_expected
.
to
render_template
:buy_storage
}
end
end
context
'with :new_route_storage_purchase disabled'
do
it
'assigns the group for the addon'
do
before
do
buy_storage
allow
(
Gitlab
::
SubscriptionPortal
::
Client
)
.
to
receive
(
:get_plans
).
with
(
tags:
[
'STORAGE_PLAN'
])
.
and_return
({
success:
true
,
data:
[{
'id'
=>
'ci_minutes'
}]
})
stub_feature_flags
(
new_route_ci_minutes_purchase:
false
)
expect
(
assigns
(
:group
)).
to
eq
group
sign_in
(
user
)
expect
(
assigns
(
:account_id
)).
to
eq
nil
end
end
it
{
is_expected
.
to
have_gitlab_http_status
(
:not_found
)
}
context
'with :new_route_storage_purchase disabled'
do
before
do
stub_feature_flags
(
new_route_storage_purchase:
false
)
end
it
{
is_expected
.
to
have_gitlab_http_status
(
:not_found
)
}
end
end
end
end
end
end
...
@@ -389,14 +394,16 @@ RSpec.describe SubscriptionsController do
...
@@ -389,14 +394,16 @@ RSpec.describe SubscriptionsController do
selected_group
.
add_owner
(
user
)
selected_group
.
add_owner
(
user
)
allow_next_instance_of
(
allow_next_instance_of
(
GitlabSubscriptions
::
F
ilter
PurchaseEligibleNamespacesService
,
GitlabSubscriptions
::
F
etch
PurchaseEligibleNamespacesService
,
user:
user
,
user:
user
,
plan_id:
params
[
:subscription
][
:plan_id
],
plan_id:
params
[
:subscription
][
:plan_id
],
namespaces:
[
selected_group
]
namespaces:
[
selected_group
]
)
do
|
instance
|
)
do
|
instance
|
allow
(
instance
)
allow
(
instance
)
.
to
receive
(
:execute
)
.
to
receive
(
:execute
)
.
and_return
(
instance_double
(
ServiceResponse
,
success?:
true
,
payload:
[
selected_group
]))
.
and_return
(
instance_double
(
ServiceResponse
,
success?:
true
,
payload:
[{
namespace:
selected_group
,
account_id:
nil
}])
)
end
end
end
end
...
@@ -439,7 +446,7 @@ RSpec.describe SubscriptionsController do
...
@@ -439,7 +446,7 @@ RSpec.describe SubscriptionsController do
selected_group
.
add_owner
(
user
)
selected_group
.
add_owner
(
user
)
allow_next_instance_of
(
allow_next_instance_of
(
GitlabSubscriptions
::
F
ilter
PurchaseEligibleNamespacesService
,
GitlabSubscriptions
::
F
etch
PurchaseEligibleNamespacesService
,
user:
user
,
user:
user
,
plan_id:
params
[
:subscription
][
:plan_id
],
plan_id:
params
[
:subscription
][
:plan_id
],
namespaces:
[
selected_group
]
namespaces:
[
selected_group
]
...
...
ee/spec/helpers/subscriptions_helper_spec.rb
View file @
704524b1
...
@@ -134,10 +134,11 @@ RSpec.describe SubscriptionsHelper do
...
@@ -134,10 +134,11 @@ RSpec.describe SubscriptionsHelper do
end
end
describe
'#buy_addon_data'
do
describe
'#buy_addon_data'
do
subject
(
:buy_addon_data
)
{
helper
.
buy_addon_data
(
group
,
anchor
,
purchased_product
)
}
subject
(
:buy_addon_data
)
{
helper
.
buy_addon_data
(
group
,
a
ccount_id
,
a
nchor
,
purchased_product
)
}
let_it_be
(
:group
)
{
create
(
:group
,
name:
'My Namespace'
)
}
let_it_be
(
:group
)
{
create
(
:group
,
name:
'My Namespace'
)
}
let_it_be
(
:user
)
{
create
(
:user
,
name:
'First Last'
)
}
let_it_be
(
:user
)
{
create
(
:user
,
name:
'First Last'
)
}
let_it_be
(
:account_id
)
{
'111111111111'
}
let
(
:anchor
)
{
'pipelines-quota-tab'
}
let
(
:anchor
)
{
'pipelines-quota-tab'
}
let
(
:purchased_product
)
{
'CI Minutes'
}
let
(
:purchased_product
)
{
'CI Minutes'
}
...
@@ -150,7 +151,7 @@ RSpec.describe SubscriptionsHelper do
...
@@ -150,7 +151,7 @@ RSpec.describe SubscriptionsHelper do
it
{
is_expected
.
to
include
(
namespace_id:
group
.
id
.
to_s
)
}
it
{
is_expected
.
to
include
(
namespace_id:
group
.
id
.
to_s
)
}
it
{
is_expected
.
to
include
(
source:
'some_source'
)
}
it
{
is_expected
.
to
include
(
source:
'some_source'
)
}
it
{
is_expected
.
to
include
(
group_data:
%Q{[{"id":
#{
group
.
id
}
,"account_id":
null
,"name":"My Namespace","users":1,"guests":0}]}
)
}
it
{
is_expected
.
to
include
(
group_data:
%Q{[{"id":
#{
group
.
id
}
,"account_id":
"
#{
account_id
}
"
,"name":"My Namespace","users":1,"guests":0}]}
)
}
it
{
is_expected
.
to
include
(
redirect_after_success:
group_usage_quotas_path
(
group
,
anchor:
anchor
,
purchased_product:
purchased_product
))
}
it
{
is_expected
.
to
include
(
redirect_after_success:
group_usage_quotas_path
(
group
,
anchor:
anchor
,
purchased_product:
purchased_product
))
}
end
end
end
end
ee/spec/lib/gitlab/subscription_portal/clients/graphql_spec.rb
View file @
704524b1
...
@@ -322,6 +322,7 @@ RSpec.describe Gitlab::SubscriptionPortal::Clients::Graphql do
...
@@ -322,6 +322,7 @@ RSpec.describe Gitlab::SubscriptionPortal::Clients::Graphql do
query FilterEligibleNamespaces($customerUid: Int!, $namespaces: [GitlabNamespaceInput!]!, $planId: ID, $eligibleForPurchase: Boolean) {
query FilterEligibleNamespaces($customerUid: Int!, $namespaces: [GitlabNamespaceInput!]!, $planId: ID, $eligibleForPurchase: Boolean) {
namespaceEligibility(customerUid: $customerUid, namespaces: $namespaces, planId: $planId, eligibleForPurchase: $eligibleForPurchase) {
namespaceEligibility(customerUid: $customerUid, namespaces: $namespaces, planId: $planId, eligibleForPurchase: $eligibleForPurchase) {
id
id
accountId: zuoraAccountId
}
}
}
}
GQL
GQL
...
@@ -333,7 +334,9 @@ RSpec.describe Gitlab::SubscriptionPortal::Clients::Graphql do
...
@@ -333,7 +334,9 @@ RSpec.describe Gitlab::SubscriptionPortal::Clients::Graphql do
response
=
{
response
=
{
data:
{
data:
{
'data'
=>
{
'data'
=>
{
'namespaceEligibility'
=>
[{
'id'
=>
1
},
{
'id'
=>
3
}]
'namespaceEligibility'
=>
[
{
'id'
=>
1
},
{
'id'
=>
3
}
]
}
}
}
}
}
}
...
...
ee/spec/services/gitlab_subscriptions/f
ilter
_purchase_eligible_namespaces_service_spec.rb
→
ee/spec/services/gitlab_subscriptions/f
etch
_purchase_eligible_namespaces_service_spec.rb
View file @
704524b1
...
@@ -2,14 +2,14 @@
...
@@ -2,14 +2,14 @@
require
'spec_helper'
require
'spec_helper'
RSpec
.
describe
GitlabSubscriptions
::
F
ilter
PurchaseEligibleNamespacesService
do
RSpec
.
describe
GitlabSubscriptions
::
F
etch
PurchaseEligibleNamespacesService
do
describe
'#execute'
do
describe
'#execute'
do
let_it_be
(
:user
)
{
build
(
:user
)
}
let_it_be
(
:user
)
{
build
(
:user
)
}
let_it_be
(
:namespace_1
)
{
create
(
:namespace
)
}
let_it_be
(
:namespace_1
)
{
create
(
:namespace
)
}
let_it_be
(
:namespace_2
)
{
create
(
:namespace
)
}
let_it_be
(
:namespace_2
)
{
create
(
:namespace
)
}
context
'when no namespaces are supplied'
do
context
'when no namespaces are supplied'
do
it
'returns an
empty array
'
,
:aggregate_failures
do
it
'returns an
array with an empty hash
'
,
:aggregate_failures
do
result
=
described_class
.
new
(
user:
user
,
plan_id:
'test'
,
namespaces:
[]).
execute
result
=
described_class
.
new
(
user:
user
,
plan_id:
'test'
,
namespaces:
[]).
execute
expect
(
result
).
to
be_success
expect
(
result
).
to
be_success
...
@@ -71,7 +71,10 @@ RSpec.describe GitlabSubscriptions::FilterPurchaseEligibleNamespacesService do
...
@@ -71,7 +71,10 @@ RSpec.describe GitlabSubscriptions::FilterPurchaseEligibleNamespacesService do
allow
(
Gitlab
::
SubscriptionPortal
::
Client
)
allow
(
Gitlab
::
SubscriptionPortal
::
Client
)
.
to
receive
(
:filter_purchase_eligible_namespaces
)
.
to
receive
(
:filter_purchase_eligible_namespaces
)
.
with
(
user
,
[
namespace_1
,
namespace_2
],
plan_id:
'test'
,
any_self_service_plan:
nil
)
.
with
(
user
,
[
namespace_1
,
namespace_2
],
plan_id:
'test'
,
any_self_service_plan:
nil
)
.
and_return
(
success:
true
,
data:
[{
'id'
=>
namespace_1
.
id
},
{
'id'
=>
namespace_2
.
id
}])
.
and_return
(
success:
true
,
data:
[
{
'id'
=>
namespace_1
.
id
,
'accountId'
=>
nil
},
{
'id'
=>
namespace_2
.
id
,
'accountId'
=>
nil
}
])
end
end
it
'does not filter any namespaces'
,
:aggregate_failures
do
it
'does not filter any namespaces'
,
:aggregate_failures
do
...
@@ -79,16 +82,21 @@ RSpec.describe GitlabSubscriptions::FilterPurchaseEligibleNamespacesService do
...
@@ -79,16 +82,21 @@ RSpec.describe GitlabSubscriptions::FilterPurchaseEligibleNamespacesService do
result
=
described_class
.
new
(
user:
user
,
plan_id:
'test'
,
namespaces:
namespaces
).
execute
result
=
described_class
.
new
(
user:
user
,
plan_id:
'test'
,
namespaces:
namespaces
).
execute
expect
(
result
).
to
be_success
expect
(
result
).
to
be_success
expect
(
result
.
payload
).
to
eq
namespaces
expect
(
result
.
payload
).
to
match_array
[
namespace_result
(
namespace_1
,
nil
),
namespace_result
(
namespace_2
,
nil
)
]
end
end
end
end
context
'when the user has a namespace ineligible'
do
context
'when the user has a namespace ineligible'
do
let
(
:account_id
)
{
'111111111'
}
before
do
before
do
allow
(
Gitlab
::
SubscriptionPortal
::
Client
)
allow
(
Gitlab
::
SubscriptionPortal
::
Client
)
.
to
receive
(
:filter_purchase_eligible_namespaces
)
.
to
receive
(
:filter_purchase_eligible_namespaces
)
.
with
(
user
,
[
namespace_1
,
namespace_2
],
plan_id:
'test'
,
any_self_service_plan:
nil
)
.
with
(
user
,
[
namespace_1
,
namespace_2
],
plan_id:
'test'
,
any_self_service_plan:
nil
)
.
and_return
(
success:
true
,
data:
[{
'id'
=>
namespace_1
.
id
}])
.
and_return
(
success:
true
,
data:
[{
'id'
=>
namespace_1
.
id
,
'accountId'
=>
account_id
}])
end
end
it
'is filtered from the results'
,
:aggregate_failures
do
it
'is filtered from the results'
,
:aggregate_failures
do
...
@@ -96,7 +104,9 @@ RSpec.describe GitlabSubscriptions::FilterPurchaseEligibleNamespacesService do
...
@@ -96,7 +104,9 @@ RSpec.describe GitlabSubscriptions::FilterPurchaseEligibleNamespacesService do
result
=
described_class
.
new
(
user:
user
,
plan_id:
'test'
,
namespaces:
namespaces
).
execute
result
=
described_class
.
new
(
user:
user
,
plan_id:
'test'
,
namespaces:
namespaces
).
execute
expect
(
result
).
to
be_success
expect
(
result
).
to
be_success
expect
(
result
.
payload
).
to
eq
[
namespace_1
]
expect
(
result
.
payload
).
to
match_array
[
namespace_result
(
namespace_1
,
account_id
)
]
end
end
end
end
...
@@ -113,8 +123,16 @@ RSpec.describe GitlabSubscriptions::FilterPurchaseEligibleNamespacesService do
...
@@ -113,8 +123,16 @@ RSpec.describe GitlabSubscriptions::FilterPurchaseEligibleNamespacesService do
result
=
described_class
.
new
(
user:
user
,
namespaces:
namespaces
,
any_self_service_plan:
true
).
execute
result
=
described_class
.
new
(
user:
user
,
namespaces:
namespaces
,
any_self_service_plan:
true
).
execute
expect
(
result
).
to
be_success
expect
(
result
).
to
be_success
expect
(
result
.
payload
).
to
eq
[
namespace_1
]
expect
(
result
.
payload
).
to
match_array
[
namespace_result
(
namespace_1
,
nil
)
]
end
end
end
end
end
end
private
def
namespace_result
(
namespace
,
account_id
)
{
namespace:
namespace
,
account_id:
account_id
}
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