Commit 5f1cc738 authored by Stan Hu's avatar Stan Hu

Merge branch 'skip-historical-max-check-on-downgrades' into 'master'

Allow downgrade when no users were added in previous period

See merge request !1490
parents d893b691 3d4a8c7d
...@@ -2,7 +2,7 @@ class License < ActiveRecord::Base ...@@ -2,7 +2,7 @@ class License < ActiveRecord::Base
include ActionView::Helpers::NumberHelper include ActionView::Helpers::NumberHelper
validate :valid_license validate :valid_license
validate :active_user_count, if: :new_record?, unless: :validate_with_trueup? validate :check_users_limit, if: :new_record?, unless: :validate_with_trueup?
validate :check_trueup, unless: :persisted?, if: :validate_with_trueup? validate :check_trueup, unless: :persisted?, if: :validate_with_trueup?
validate :not_expired, unless: :persisted? validate :not_expired, unless: :persisted?
...@@ -99,6 +99,10 @@ class License < ActiveRecord::Base ...@@ -99,6 +99,10 @@ class License < ActiveRecord::Base
restricted_attr(:previous_user_count) restricted_attr(:previous_user_count)
end end
def current_active_users_count
@current_active_users_count ||= User.active.count
end
def validate_with_trueup? def validate_with_trueup?
[restricted_attr(:trueup_quantity), [restricted_attr(:trueup_quantity),
restricted_attr(:trueup_from), restricted_attr(:trueup_from),
...@@ -127,37 +131,41 @@ class License < ActiveRecord::Base ...@@ -127,37 +131,41 @@ class License < ActiveRecord::Base
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
def historical_max(from, to) def historical_max(from = nil, to = nil)
from ||= starts_at - 1.year
to ||= starts_at
HistoricalData.during(from..to).maximum(:active_user_count) || 0 HistoricalData.during(from..to).maximum(:active_user_count) || 0
end end
def active_user_count def check_users_limit
return unless restricted_user_count return unless restricted_user_count
historical_user_count = historical_max((starts_at - 1.year), starts_at) if previous_user_count && (historical_max <= previous_user_count)
overage = historical_user_count - restricted_user_count return if restricted_user_count >= current_active_users_count
else
return if historical_user_count <= restricted_user_count return if restricted_user_count >= historical_max
end
add_limit_error(user_count: historical_user_count, restricted_user_count: restricted_user_count, overage: overage) overage = historical_max - restricted_user_count
add_limit_error(user_count: historical_max, restricted_user_count: restricted_user_count, overage: overage)
end end
def check_trueup def check_trueup
trueup_qty = restrictions[:trueup_quantity] trueup_qty = restrictions[:trueup_quantity]
trueup_from = Date.parse(restrictions[:trueup_from]) rescue (starts_at - 1.year) trueup_from = Date.parse(restrictions[:trueup_from]) rescue (starts_at - 1.year)
trueup_to = Date.parse(restrictions[:trueup_to]) rescue starts_at trueup_to = Date.parse(restrictions[:trueup_to]) rescue starts_at
active_user_count = User.active.count
max_historical = historical_max(trueup_from, trueup_to) max_historical = historical_max(trueup_from, trueup_to)
overage = active_user_count - restricted_user_count overage = current_active_users_count - restricted_user_count
expected_trueup_qty = if previous_user_count expected_trueup_qty = if previous_user_count
max_historical - previous_user_count max_historical - previous_user_count
else else
max_historical - active_user_count max_historical - current_active_users_count
end end
if trueup_qty >= expected_trueup_qty if trueup_qty >= expected_trueup_qty
if restricted_user_count < active_user_count if restricted_user_count < current_active_users_count
add_limit_error(trueup: true, user_count: active_user_count, restricted_user_count: restricted_user_count, overage: overage) add_limit_error(trueup: true, user_count: current_active_users_count, restricted_user_count: restricted_user_count, overage: overage)
end end
else else
message = "You have applied a True-up for #{trueup_qty} #{"user".pluralize(trueup_qty)} " message = "You have applied a True-up for #{trueup_qty} #{"user".pluralize(trueup_qty)} "
......
...@@ -90,16 +90,6 @@ describe License do ...@@ -90,16 +90,6 @@ describe License do
end end
context 'with true-up info' do context 'with true-up info' do
def set_restrictions(opts)
gl_license.restrictions = {
active_user_count: opts[:restricted_user_count],
previous_user_count: opts[:previous_user_count],
trueup_quantity: opts[:trueup_quantity],
trueup_from: (Date.today - 1.year).to_s,
trueup_to: Date.today.to_s
}
end
context 'when quantity is ok' do context 'when quantity is ok' do
before do before do
set_restrictions(restricted_user_count: 5, trueup_quantity: 10) set_restrictions(restricted_user_count: 5, trueup_quantity: 10)
...@@ -170,7 +160,7 @@ describe License do ...@@ -170,7 +160,7 @@ describe License do
gl_license.expires_at = Date.yesterday gl_license.expires_at = Date.yesterday
end end
it "is valid" do it "is invalid" do
expect(license).not_to be_valid expect(license).not_to be_valid
end end
end end
...@@ -185,6 +175,32 @@ describe License do ...@@ -185,6 +175,32 @@ describe License do
end end
end end
end end
describe 'downgrade' do
context 'when more users were added in previous period' do
before do
HistoricalData.create!(date: 6.months.ago, active_user_count: 15)
set_restrictions(restricted_user_count: 5, previous_user_count: 10)
end
it 'is invalid without a true-up' do
expect(license).not_to be_valid
end
end
context 'when no users were added in the previous period' do
before do
HistoricalData.create!(date: 6.months.ago, active_user_count: 15)
set_restrictions(restricted_user_count: 10, previous_user_count: 15)
end
it 'is valid' do
expect(license).to be_valid
end
end
end
end end
describe "Class methods" do describe "Class methods" do
...@@ -328,4 +344,14 @@ describe License do ...@@ -328,4 +344,14 @@ describe License do
build(:license, data: gl_license.export) build(:license, data: gl_license.export)
end end
end end
def set_restrictions(opts)
gl_license.restrictions = {
active_user_count: opts[:restricted_user_count],
previous_user_count: opts[:previous_user_count],
trueup_quantity: opts[:trueup_quantity],
trueup_from: (Date.today - 1.year).to_s,
trueup_to: Date.today.to_s
}
end
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