Commit ae94bd46 authored by James Lopez's avatar James Lopez

Merge branch 'jh-skip_true_up' into 'master'

Account for skip_true_up flag in License validation

See merge request gitlab-org/gitlab!65793
parents dfc21444 0e06171b
...@@ -498,6 +498,8 @@ class License < ApplicationRecord ...@@ -498,6 +498,8 @@ class License < ApplicationRecord
end end
def validate_with_trueup? def validate_with_trueup?
return false if restricted_attr(:skip_true_up)
[restricted_attr(:trueup_quantity), [restricted_attr(:trueup_quantity),
restricted_attr(:trueup_from), restricted_attr(:trueup_from),
restricted_attr(:trueup_to)].all?(&:present?) restricted_attr(:trueup_to)].all?(&:present?)
......
...@@ -5,24 +5,118 @@ require "spec_helper" ...@@ -5,24 +5,118 @@ require "spec_helper"
RSpec.describe License do RSpec.describe License do
using RSpec::Parameterized::TableSyntax using RSpec::Parameterized::TableSyntax
subject(:license) { build(:license, data: gl_license.export) }
let(:gl_license) { build(:gitlab_license) } let(:gl_license) { build(:gitlab_license) }
let(:license) { build(:license, data: gl_license.export) }
describe "Validation" do describe 'validations' do
describe "Valid license" do describe '#valid_license' do
context "when the license is provided" do context 'when the license is provided' do
it "is valid" do it 'is valid' do
expect(license).to be_valid expect(license).to be_valid
end end
end end
context "when no license is provided" do context 'when no license is provided' do
before do before do
license.data = nil license.data = nil
end end
it "is invalid" do it 'is invalid' do
expect(license).not_to be_valid
end
end
end
describe '#check_trueup' do
let(:active_user_count) { described_class.current.daily_billable_users_count + 10 }
let(:date) { described_class.current.starts_at }
before do
create(:historical_data, recorded_at: date, active_user_count: active_user_count)
end
context 'when skip_true_up is true on the license' do
it 'does not add errors for invalid true up' do
set_restrictions(restricted_user_count: 10, trueup_quantity: 8, skip_true_up: true)
expect(license).to be_valid
end
end
context 'when skip_true_up is false on the license' do
it 'adds errors for invalid true up figures' do
set_restrictions(restricted_user_count: 10, trueup_quantity: 8, skip_true_up: false)
expect(license).not_to be_valid
expect(license.errors.full_messages.to_sentence)
.to include 'You have applied a True-up for 8 users but you need one for 10 users'
end
end
context 'when skip_true_up is not present on the license' do
it 'adds errors for invalid true up figures' do
set_restrictions(restricted_user_count: 10, trueup_quantity: 8)
expect(license).not_to be_valid expect(license).not_to be_valid
expect(license.errors.full_messages.to_sentence)
.to include 'You have applied a True-up for 8 users but you need one for 10 users'
end
end
context 'when quantity is ok' do
before do
set_restrictions(restricted_user_count: 5, trueup_quantity: 10)
end
it 'is valid' do
expect(license).to be_valid
end
context 'but active users exceeds restricted user count' do
it 'is invalid' do
create_list(:user, 6)
expect(license).not_to be_valid
end
end
end
context 'when quantity is wrong' do
it 'is invalid' do
set_restrictions(restricted_user_count: 5, trueup_quantity: 8)
expect(license).not_to be_valid
end
end
context 'when previous user count is not present' do
before do
set_restrictions(restricted_user_count: 5, trueup_quantity: 7)
end
it 'uses current active user count to calculate the expected true-up' do
create_list(:user, 3)
expect(license).to be_valid
end
context 'with wrong true-up quantity' do
it 'is invalid' do
create_list(:user, 2)
expect(license).not_to be_valid
end
end
end
context 'when previous user count is present' do
before do
set_restrictions(restricted_user_count: 5, trueup_quantity: 6, previous_user_count: 4)
end
it 'uses it to calculate the expected true-up' do
expect(license).to be_valid
end end
end end
end end
...@@ -131,15 +225,14 @@ RSpec.describe License do ...@@ -131,15 +225,14 @@ RSpec.describe License do
end end
end end
end end
end
describe "Historical active user count" do describe 'Historical active user count' do
let(:active_user_count) { described_class.current.daily_billable_users_count + 10 } let(:active_user_count) { described_class.current.daily_billable_users_count + 10 }
let(:date) { described_class.current.starts_at } let(:date) { described_class.current.starts_at }
let!(:historical_data) { create(:historical_data, recorded_at: date, active_user_count: active_user_count) } let!(:historical_data) { create(:historical_data, recorded_at: date, active_user_count: active_user_count) }
context "when there is no active user count restriction" do context 'when there is no active user count restriction' do
it "is valid" do it 'is valid' do
expect(license).to be_valid expect(license).to be_valid
end end
end end
...@@ -172,143 +265,86 @@ RSpec.describe License do ...@@ -172,143 +265,86 @@ RSpec.describe License do
end end
end end
context "when the active user count restriction is exceeded" do context 'when the active user count restriction is exceeded' do
before do before do
gl_license.restrictions = { active_user_count: active_user_count - 1 } gl_license.restrictions = { active_user_count: active_user_count - 1 }
end end
context "when the license started" do context 'when the license started' do
it "is invalid" do it 'is invalid' do
expect(license).not_to be_valid expect(license).not_to be_valid
end end
end end
context "after the license started" do context 'after the license started' do
let(:date) { Date.current } let(:date) { Date.current }
it "is valid" do it 'is valid' do
expect(license).to be_valid expect(license).to be_valid
end end
end end
context "in the year before the license started" do context 'in the year before the license started' do
let(:date) { described_class.current.starts_at - 6.months } let(:date) { described_class.current.starts_at - 6.months }
it "is invalid" do it 'is invalid' do
expect(license).not_to be_valid expect(license).not_to be_valid
end end
end end
context "earlier than a year before the license started" do context 'earlier than a year before the license started' do
let(:date) { described_class.current.starts_at - 2.years } let(:date) { described_class.current.starts_at - 2.years }
it "is valid" do it 'is valid' do
expect(license).to be_valid expect(license).to be_valid
end end
end end
end end
context "when the active user count restriction is not exceeded" do context 'when the active user count restriction is not exceeded' do
before do before do
gl_license.restrictions = { active_user_count: active_user_count + 1 } gl_license.restrictions = { active_user_count: active_user_count + 1 }
end end
it "is valid" do it 'is valid' do
expect(license).to be_valid expect(license).to be_valid
end end
end end
context "when the active user count is met exactly" do context 'when the active user count is met exactly' do
it "is valid" do it 'is valid' do
active_user_count = 100 active_user_count = 100
gl_license.restrictions = { active_user_count: active_user_count } gl_license.restrictions = { active_user_count: active_user_count }
expect(license).to be_valid expect(license).to be_valid
end end
end end
context 'with true-up info' do
context 'when quantity is ok' do
before do
set_restrictions(restricted_user_count: 5, trueup_quantity: 10)
end
it 'is valid' do
expect(license).to be_valid
end
context 'but active users exceeds restricted user count' do
it 'is invalid' do
create_list(:user, 6)
expect(license).not_to be_valid
end
end end
end end
context 'when quantity is wrong' do describe '#not_expired' do
it 'is invalid' do
set_restrictions(restricted_user_count: 5, trueup_quantity: 8)
expect(license).not_to be_valid
end
end
context 'when previous user count is not present' do
before do
set_restrictions(restricted_user_count: 5, trueup_quantity: 7)
end
it 'uses current active user count to calculate the expected true-up' do
create_list(:user, 3)
expect(license).to be_valid
end
context 'with wrong true-up quantity' do
it 'is invalid' do
create_list(:user, 2)
expect(license).not_to be_valid
end
end
end
context 'when previous user count is present' do
before do
set_restrictions(restricted_user_count: 5, trueup_quantity: 6, previous_user_count: 4)
end
it 'uses it to calculate the expected true-up' do
expect(license).to be_valid
end
end
end
end
describe "Not expired" do
context "when the license doesn't expire" do context "when the license doesn't expire" do
it "is valid" do it 'is valid' do
expect(license).to be_valid expect(license).to be_valid
end end
end end
context "when the license has expired" do context 'when the license has expired' do
before do before do
gl_license.expires_at = Date.yesterday gl_license.expires_at = Date.yesterday
end end
it "is invalid" do it 'is invalid' do
expect(license).not_to be_valid expect(license).not_to be_valid
end end
end end
context "when the license has yet to expire" do context 'when the license has yet to expire' do
before do before do
gl_license.expires_at = Date.tomorrow gl_license.expires_at = Date.tomorrow
end end
it "is valid" do it 'is valid' do
expect(license).to be_valid expect(license).to be_valid
end end
end end
...@@ -1437,8 +1473,9 @@ RSpec.describe License do ...@@ -1437,8 +1473,9 @@ RSpec.describe License do
previous_user_count: opts[:previous_user_count], previous_user_count: opts[:previous_user_count],
trueup_quantity: opts[:trueup_quantity], trueup_quantity: opts[:trueup_quantity],
trueup_from: (date - 1.year).to_s, trueup_from: (date - 1.year).to_s,
trueup_to: date.to_s trueup_to: date.to_s,
} skip_true_up: opts[:skip_true_up]
}.compact
end end
describe '#paid?' do describe '#paid?' do
......
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