Commit 31f768bb authored by Douglas Barbosa Alexandre's avatar Douglas Barbosa Alexandre

Merge branch '327691_fix_previous_license_period' into 'master'

Fix previous license period

See merge request gitlab-org/gitlab!72330
parents 2731aa70 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
......
...@@ -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: :persisted? validate :not_expired, if: :new_record?
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
......
This diff is collapsed.
# 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
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment