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
caec1166
Commit
caec1166
authored
Oct 20, 2021
by
Corinna Wiesner
Committed by
Douglas Barbosa Alexandre
Oct 20, 2021
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix previous license period
parent
df5a6a0b
Changes
4
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
250 additions
and
245 deletions
+250
-245
ee/app/controllers/concerns/admin/license_request.rb
ee/app/controllers/concerns/admin/license_request.rb
+0
-1
ee/app/models/license.rb
ee/app/models/license.rb
+25
-31
ee/spec/models/license_spec.rb
ee/spec/models/license_spec.rb
+118
-213
ee/spec/support/shared_examples/models/license_shared_examples.rb
...support/shared_examples/models/license_shared_examples.rb
+107
-0
No files found.
ee/app/controllers/concerns/admin/license_request.rb
View file @
caec1166
...
@@ -8,7 +8,6 @@ module Admin
...
@@ -8,7 +8,6 @@ module Admin
@license
||=
begin
@license
||=
begin
License
.
reset_current
License
.
reset_current
License
.
reset_future_dated
License
.
reset_future_dated
License
.
reset_previous
License
.
current
License
.
current
end
end
end
end
...
...
ee/app/models/license.rb
View file @
caec1166
...
@@ -258,16 +258,15 @@ class License < ApplicationRecord
...
@@ -258,16 +258,15 @@ class License < ApplicationRecord
validate
:valid_license
validate
:valid_license
validate
:check_users_limit
,
if: :new_record?
,
unless:
[
:validate_with_trueup?
,
:reconciliation_completed?
]
validate
:check_users_limit
,
if: :new_record?
,
unless:
[
:validate_with_trueup?
,
:reconciliation_completed?
]
validate
:check_trueup
,
unless:
[
:persisted?
,
:reconciliation_completed?
],
if: :validate_with_trueup?
validate
:check_trueup
,
unless:
:reconciliation_completed?
,
if:
[
:new_record?
,
:validate_with_trueup?
]
validate
:check_restricted_user_count
,
if: :reconciliation_completed?
validate
:check_restricted_user_count
,
if: :reconciliation_completed?
validate
:not_expired
,
unless: :persiste
d?
validate
:not_expired
,
if: :new_recor
d?
before_validation
:reset_license
,
if: :data_changed?
before_validation
:reset_license
,
if: :data_changed?
after_create
:update_trial_setting
after_create
:update_trial_setting
after_commit
:reset_current
after_commit
:reset_current
after_commit
:reset_future_dated
,
on:
[
:create
,
:destroy
]
after_commit
:reset_future_dated
,
on:
[
:create
,
:destroy
]
after_commit
:reset_previous
,
on:
[
:create
,
:destroy
]
scope
:cloud
,
->
{
where
(
cloud:
true
)
}
scope
:cloud
,
->
{
where
(
cloud:
true
)
}
scope
:recent
,
->
{
reorder
(
id: :desc
)
}
scope
:recent
,
->
{
reorder
(
id: :desc
)
}
...
@@ -331,14 +330,6 @@ class License < ApplicationRecord
...
@@ -331,14 +330,6 @@ class License < ApplicationRecord
Gitlab
::
SafeRequestStore
.
delete
(
:future_dated_license
)
Gitlab
::
SafeRequestStore
.
delete
(
:future_dated_license
)
end
end
def
previous
Gitlab
::
SafeRequestStore
.
fetch
(
:previous_license
)
{
load_previous
}
end
def
reset_previous
Gitlab
::
SafeRequestStore
.
delete
(
:previous_license
)
end
def
global_feature?
(
feature
)
def
global_feature?
(
feature
)
GLOBAL_FEATURES
.
include?
(
feature
)
GLOBAL_FEATURES
.
include?
(
feature
)
end
end
...
@@ -377,10 +368,6 @@ class License < ApplicationRecord
...
@@ -377,10 +368,6 @@ class License < ApplicationRecord
def
load_future_dated
def
load_future_dated
self
.
last_hundred
.
find
{
|
license
|
license
.
valid?
&&
license
.
future_dated?
}
self
.
last_hundred
.
find
{
|
license
|
license
.
valid?
&&
license
.
future_dated?
}
end
end
def
load_previous
self
.
last_hundred
.
find
{
|
license
|
license
.
valid?
&&
!
license
.
future_dated?
&&
license
!=
License
.
current
}
end
end
end
def
data_filename
def
data_filename
...
@@ -641,10 +628,6 @@ class License < ApplicationRecord
...
@@ -641,10 +628,6 @@ class License < ApplicationRecord
self
.
class
.
reset_future_dated
self
.
class
.
reset_future_dated
end
end
def
reset_previous
self
.
class
.
reset_previous
end
def
reset_license
def
reset_license
@license
=
nil
@license
=
nil
end
end
...
@@ -655,12 +638,27 @@ class License < ApplicationRecord
...
@@ -655,12 +638,27 @@ class License < ApplicationRecord
self
.
errors
.
add
(
:base
,
_
(
'The license key is invalid. Make sure it is exactly as you received it from GitLab Inc.'
))
self
.
errors
.
add
(
:base
,
_
(
'The license key is invalid. Make sure it is exactly as you received it from GitLab Inc.'
))
end
end
# This method, `previous_started_at` and `previous_expired_at` are
# only used in the validation methods `check_users_limit` and check_trueup
# which are only used when uploading/creating a new license.
# The method will not work in other workflows since it has a dependency to
# use the current license as the previous in the system.
def
prior_historical_max
def
prior_historical_max
@prior_historical_max
||=
begin
strong_memoize
(
:prior_historical_max
)
do
historical_max
(
from:
previous_started_at
,
to:
previous_expired_at
)
historical_max
(
from:
previous_started_at
,
to:
previous_expired_at
)
end
end
end
end
# See comment for `prior_historical_max`.
def
previous_started_at
(
License
.
current
&
.
starts_at
||
starts_at
-
1
.
year
).
beginning_of_day
end
# See comment for `prior_historical_max`.
def
previous_expired_at
(
License
.
current
&
.
expires_at
||
expires_at
&&
expires_at
-
1
.
year
||
starts_at
).
end_of_day
end
def
restricted_user_count_with_threshold
def
restricted_user_count_with_threshold
(
restricted_user_count
*
(
1
+
ALLOWED_PERCENTAGE_OF_USERS_OVERAGE
)).
to_i
(
restricted_user_count
*
(
1
+
ALLOWED_PERCENTAGE_OF_USERS_OVERAGE
)).
to_i
end
end
...
@@ -669,15 +667,19 @@ class License < ApplicationRecord
...
@@ -669,15 +667,19 @@ class License < ApplicationRecord
return
if
cloud_license?
return
if
cloud_license?
return
unless
restricted_user_count
return
unless
restricted_user_count
user_count
=
daily_billable_users_count
current_period
=
true
if
previous_user_count
&&
(
prior_historical_max
<=
previous_user_count
)
if
previous_user_count
&&
(
prior_historical_max
<=
previous_user_count
)
return
if
restricted_user_count_with_threshold
>=
daily_billable_users_count
return
if
restricted_user_count_with_threshold
>=
daily_billable_users_count
else
else
return
if
restricted_user_count_with_threshold
>=
prior_historical_max
return
if
restricted_user_count_with_threshold
>=
prior_historical_max
end
user_count
=
prior_historical_max
==
0
?
daily_billable_users_count
:
prior_historical_max
user_count
=
prior_historical_max
current_period
=
false
end
add_limit_error
(
current_period:
prior_historical_max
==
0
,
user_count:
user_count
)
add_limit_error
(
current_period:
current_period
,
user_count:
user_count
)
end
end
def
check_trueup
def
check_trueup
...
@@ -731,14 +733,6 @@ class License < ApplicationRecord
...
@@ -731,14 +733,6 @@ class License < ApplicationRecord
self
.
errors
.
add
(
:base
,
_
(
'This license has already expired.'
))
self
.
errors
.
add
(
:base
,
_
(
'This license has already expired.'
))
end
end
def
previous_started_at
(
License
.
previous
&
.
starts_at
||
starts_at
-
1
.
year
).
beginning_of_day
end
def
previous_expired_at
(
License
.
previous
&
.
expires_at
||
starts_at
).
end_of_day
end
def
starts_at_for_historical_data
def
starts_at_for_historical_data
(
starts_at
||
Time
.
current
-
1
.
year
).
beginning_of_day
(
starts_at
||
Time
.
current
-
1
.
year
).
beginning_of_day
end
end
...
...
ee/spec/models/license_spec.rb
View file @
caec1166
This diff is collapsed.
Click to expand it.
ee/spec/support/shared_examples/models/license_shared_examples.rb
0 → 100644
View file @
caec1166
# frozen_string_literal: true
RSpec
.
shared_examples
'valid daily billable users count compared to limit set by license checks'
do
context
'when daily billable users count is less than the restricted user count'
do
let
(
:billable_users_count
)
{
active_user_count
-
5
}
it
{
is_expected
.
to
be_valid
}
end
context
'when daily billable users count is equal to the restricted user count'
do
let
(
:billable_users_count
)
{
active_user_count
}
it
{
is_expected
.
to
be_valid
}
end
context
'when daily billable users count is equal to the restricted user count with threshold'
do
let
(
:active_user_count
)
{
10
}
let
(
:billable_users_count
)
{
11
}
it
{
is_expected
.
to
be_valid
}
end
end
RSpec
.
shared_examples
'invalid daily billable users count compared to limit set by license checks'
do
context
'when daily billable users count is greater than the restricted user count'
do
let
(
:billable_users_count
)
{
active_user_count
+
5
}
it
{
is_expected
.
not_to
be_valid
}
it
'includes the correct error message'
do
license
.
valid?
overage
=
billable_users_count
-
active_user_count
error_message
=
"This GitLab installation currently has
#{
billable_users_count
}
active users, "
\
"exceeding this license's limit of
#{
active_user_count
}
by
#{
overage
}
users. "
\
"Please upload a license for at least
#{
billable_users_count
}
users"
expect
(
license
.
errors
.
full_messages
.
to_sentence
).
to
include
(
error_message
)
end
end
end
RSpec
.
shared_examples
'valid prior historical max compared to limit set by license checks'
do
context
'when prior historical max is less than the restricted user count'
do
let
(
:billable_users_count
)
{
active_user_count
}
let
(
:prior_active_user_count
)
{
active_user_count
-
1
}
it
{
is_expected
.
to
be_valid
}
end
context
'when prior historical max is equal to the restricted user count'
do
let
(
:billable_users_count
)
{
active_user_count
}
let
(
:prior_active_user_count
)
{
active_user_count
}
it
{
is_expected
.
to
be_valid
}
end
context
'when prior historical max is equal to the restricted user count with threshold'
do
let
(
:active_user_count
)
{
10
}
let
(
:billable_users_count
)
{
active_user_count
}
let
(
:prior_active_user_count
)
{
11
}
it
{
is_expected
.
to
be_valid
}
end
end
RSpec
.
shared_examples
'invalid prior historical max compared to limit set by license checks'
do
context
'when prior historical max is greater than the restricted user count'
do
let
(
:billable_users_count
)
{
active_user_count
}
let
(
:prior_active_user_count
)
{
active_user_count
+
1
}
it
{
is_expected
.
not_to
be_valid
}
it
'includes the correct error message'
do
license
.
valid?
overage
=
prior_active_user_count
-
active_user_count
error_message
=
"During the year before this license started, "
\
"this GitLab installation had
#{
prior_active_user_count
}
active users, "
\
"exceeding this license's limit of
#{
active_user_count
}
by
#{
overage
}
user. "
\
"Please upload a license for at least
#{
prior_active_user_count
}
users"
expect
(
license
.
errors
.
full_messages
.
to_sentence
).
to
include
(
error_message
)
end
end
end
RSpec
.
shared_examples
'with previous user count checks'
do
context
'when prior historical max is less than previous user count'
do
let
(
:prior_active_user_count
)
{
previous_user_count
-
5
}
include_examples
'valid daily billable users count compared to limit set by license checks'
include_examples
'invalid daily billable users count compared to limit set by license checks'
end
context
'when prior historical max is equal to previous user count'
do
let
(
:prior_active_user_count
)
{
previous_user_count
}
include_examples
'valid daily billable users count compared to limit set by license checks'
include_examples
'invalid daily billable users count compared to limit set by license checks'
end
context
'when prior historical max is greater than previous user count'
do
include_examples
'valid prior historical max compared to limit set by license checks'
include_examples
'invalid prior historical max compared to limit set by license checks'
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