Commit d454ead8 authored by Douglas Barbosa Alexandre's avatar Douglas Barbosa Alexandre

Merge branch '281177_remove_license_params_in_max_historical_user_count' into 'master'

Remove fallback logic

See merge request gitlab-org/gitlab!54221
parents f09b5338 1ff9c074
...@@ -10,11 +10,9 @@ module Admin ...@@ -10,11 +10,9 @@ module Admin
feature_category :utilization feature_category :utilization
def show def show
historical_data = HistoricalData.in_license_term(license)
respond_to do |format| respond_to do |format|
format.csv do format.csv do
csv_data = HistoricalUserData::CsvService.new(historical_data).generate csv_data = HistoricalUserData::CsvService.new(license.historical_data).generate
send_data(csv_data, type: 'text/csv; charset=utf-8', filename: 'license_usage.csv') send_data(csv_data, type: 'text/csv; charset=utf-8', filename: 'license_usage.csv')
end end
......
...@@ -40,21 +40,15 @@ module Gitlab ...@@ -40,21 +40,15 @@ module Gitlab
::License.current.data ::License.current.data
end end
def license_starts_at
::License.current.starts_at.beginning_of_day
end
def default_max_count def default_max_count
HistoricalData.max_historical_user_count( ::License.current.historical_max(to: timestamp)
from: license_starts_at,
to: timestamp
)
end end
def historical_data def historical_data
strong_memoize(:historical_data) do strong_memoize(:historical_data) do
to_timestamp = timestamp || Time.current to_timestamp = timestamp || Time.current
HistoricalData.during(license_starts_at..to_timestamp).order(:recorded_at).last
::License.current.historical_data(to: to_timestamp).order(:recorded_at).last
end end
end end
......
...@@ -16,21 +16,8 @@ class HistoricalData < ApplicationRecord ...@@ -16,21 +16,8 @@ class HistoricalData < ApplicationRecord
) )
end end
def max_historical_user_count(license: nil, from: nil, to: nil) def max_historical_user_count(from:, to:)
license ||= License.current
starts_at = license&.starts_at || Time.current - 1.year
expires_at = license&.expires_at || Time.current
from ||= starts_at.beginning_of_day
to ||= expires_at.end_of_day
HistoricalData.during(from..to).maximum(:active_user_count) || 0 HistoricalData.during(from..to).maximum(:active_user_count) || 0
end end
def in_license_term(license)
start_date = license.starts_at.beginning_of_day
expiration_date = license.expires_at&.end_of_day || Time.current
HistoricalData.during(start_date..expiration_date)
end
end end
end end
...@@ -502,8 +502,18 @@ class License < ApplicationRecord ...@@ -502,8 +502,18 @@ class License < ApplicationRecord
overage(maximum_user_count) overage(maximum_user_count)
end end
def historical_data(from: nil, to: nil)
from ||= starts_at_for_historical_data
to ||= expires_at_for_historical_data
HistoricalData.during(from..to)
end
def historical_max(from: nil, to: nil) def historical_max(from: nil, to: nil)
HistoricalData.max_historical_user_count(license: self, from: from, to: to) from ||= starts_at_for_historical_data
to ||= expires_at_for_historical_data
HistoricalData.max_historical_user_count(from: from, to: to)
end end
def maximum_user_count def maximum_user_count
...@@ -666,4 +676,12 @@ class License < ApplicationRecord ...@@ -666,4 +676,12 @@ class License < ApplicationRecord
def previous_expired_at def previous_expired_at
(License.previous&.expires_at || starts_at).end_of_day (License.previous&.expires_at || starts_at).end_of_day
end end
def starts_at_for_historical_data
(starts_at || Time.current - 1.year).beginning_of_day
end
def expires_at_for_historical_data
(expires_at || Time.current).end_of_day
end
end end
...@@ -93,7 +93,7 @@ module EE ...@@ -93,7 +93,7 @@ module EE
usage_data[:license_md5] = license.md5 usage_data[:license_md5] = license.md5
usage_data[:license_id] = license.license_id usage_data[:license_id] = license.license_id
# rubocop: disable UsageData/LargeTable # rubocop: disable UsageData/LargeTable
usage_data[:historical_max_users] = ::HistoricalData.max_historical_user_count usage_data[:historical_max_users] = license.historical_max
# rubocop: enable UsageData/LargeTable # rubocop: enable UsageData/LargeTable
usage_data[:licensee] = license.licensee usage_data[:licensee] = license.licensee
usage_data[:license_user_count] = license.restricted_user_count usage_data[:license_user_count] = license.restricted_user_count
......
...@@ -372,8 +372,8 @@ RSpec.describe Admin::ApplicationSettingsController do ...@@ -372,8 +372,8 @@ RSpec.describe Admin::ApplicationSettingsController do
end end
before_all do before_all do
HistoricalData.create!(recorded_at: yesterday - 1.day, active_user_count: max_count) create(:historical_data, recorded_at: yesterday - 1.day, active_user_count: max_count)
HistoricalData.create!(recorded_at: yesterday, active_user_count: current_count) create(:historical_data, recorded_at: yesterday, active_user_count: current_count)
end end
before do before do
......
...@@ -44,7 +44,9 @@ RSpec.describe Admin::Licenses::UsageExportsController do ...@@ -44,7 +44,9 @@ RSpec.describe Admin::Licenses::UsageExportsController do
let(:historical_data_relation) { :historical_data_relation } let(:historical_data_relation) { :historical_data_relation }
before do before do
allow(HistoricalData).to receive(:in_license_term).with(License.current).and_return(historical_data_relation) license = build(:license)
allow(License).to receive(:current).and_return(license)
allow(license).to receive(:historical_data).and_return(historical_data_relation)
allow(HistoricalUserData::CsvService).to receive(:new).with(historical_data_relation).and_return(csv_service) allow(HistoricalUserData::CsvService).to receive(:new).with(historical_data_relation).and_return(csv_service)
end end
......
...@@ -183,7 +183,7 @@ RSpec.describe Gitlab::UsageData do ...@@ -183,7 +183,7 @@ RSpec.describe Gitlab::UsageData do
expect(subject[:license_md5]).to eq(Digest::MD5.hexdigest(license.data)) expect(subject[:license_md5]).to eq(Digest::MD5.hexdigest(license.data))
expect(subject[:license_id]).to eq(license.license_id) expect(subject[:license_id]).to eq(license.license_id)
expect(subject[:historical_max_users]).to eq(::HistoricalData.max_historical_user_count) expect(subject[:historical_max_users]).to eq(license.historical_max)
expect(subject[:licensee]).to eq(license.licensee) expect(subject[:licensee]).to eq(license.licensee)
expect(subject[:license_user_count]).to eq(license.restricted_user_count) expect(subject[:license_user_count]).to eq(license.restricted_user_count)
expect(subject[:license_starts_at]).to eq(license.starts_at) expect(subject[:license_starts_at]).to eq(license.starts_at)
......
...@@ -27,10 +27,10 @@ RSpec.describe Gitlab::SeatLinkData do ...@@ -27,10 +27,10 @@ RSpec.describe Gitlab::SeatLinkData do
let_it_be(:today_active_count) { 20 } let_it_be(:today_active_count) { 20 }
before_all do before_all do
HistoricalData.create!(recorded_at: license_start_date, active_user_count: 10) create(:historical_data, recorded_at: license_start_date, active_user_count: 10)
HistoricalData.create!(recorded_at: license_start_date + 1.day, active_user_count: max_before_today) create(:historical_data, recorded_at: license_start_date + 1.day, active_user_count: max_before_today)
HistoricalData.create!(recorded_at: utc_time - 1.day, active_user_count: yesterday_active_count) create(:historical_data, recorded_at: utc_time - 1.day, active_user_count: yesterday_active_count)
HistoricalData.create!(recorded_at: utc_time, active_user_count: today_active_count) create(:historical_data, recorded_at: utc_time, active_user_count: today_active_count)
end end
around do |example| around do |example|
......
...@@ -5,7 +5,7 @@ require 'spec_helper' ...@@ -5,7 +5,7 @@ require 'spec_helper'
RSpec.describe HistoricalData do RSpec.describe HistoricalData do
before do before do
(1..12).each do |i| (1..12).each do |i|
described_class.create!(recorded_at: Date.new(2014, i, 1), active_user_count: i * 100) create(:historical_data, recorded_at: Date.new(2014, i, 1), active_user_count: i * 100)
end end
end end
...@@ -40,156 +40,41 @@ RSpec.describe HistoricalData do ...@@ -40,156 +40,41 @@ RSpec.describe HistoricalData do
end end
describe '.max_historical_user_count' do describe '.max_historical_user_count' do
let(:current_license) { create(:license, starts_at: Date.current - 1.month, expires_at: Date.current + 1.month) } subject(:max_historical_user_count) { described_class.max_historical_user_count(from: from, to: to) }
before do let(:from) { (Date.current - 1.month).beginning_of_day }
# stub current license to cover a shorter period (one month ago until a date in the future) than the one let(:to) { (Date.current + 1.month).end_of_day }
# set for the whole test suite (1970-01-01 to a date in the future)
allow(License).to receive(:load_license).and_return(current_license)
allow(License).to receive(:current).and_return(current_license)
end
context 'with multiple historical data points for the current license' do context 'with data outside of the given period' do
context 'with stats before the given period' do
before do before do
(1..3).each do |i| create(:historical_data, recorded_at: from - 2.days, active_user_count: 10)
described_class.create!(recorded_at: Time.current - i.days, active_user_count: i * 100)
end
described_class.create!(recorded_at: Time.current - 1.year, active_user_count: 400)
end
it 'returns max user count for the duration of the current license' do
expect(described_class.max_historical_user_count).to eq(300)
end
context 'when there is no current license' do
let(:current_license) { nil }
it 'returns max user count for the past year as a fallback' do
expect(described_class.max_historical_user_count).to eq(400)
end
end
end
context 'using parameters' do
let!(:license) do
create(
:license,
starts_at: Date.new(2014, 1, 1),
expires_at: Date.new(2014, 12, 1)
)
end end
it 'returns max user count for the given license' do it 'ignores those records' do
expect(described_class.max_historical_user_count(license: license)).to eq(1200) expect(max_historical_user_count).to eq(0)
end end
it 'returns max user count for the time range' do
from = Date.new(2014, 6, 1)
to = Date.new(2014, 9, 1)
expect(described_class.max_historical_user_count(from: from, to: to)).to eq(900)
end end
end
context 'with different plans' do
using RSpec::Parameterized::TableSyntax
context 'with stats after the given period' do
before do before do
create(:group_member, :guest) create(:historical_data, recorded_at: to + 2.days, active_user_count: 10)
create(:group_member, :reporter)
described_class.track!
end end
where(:gl_plan, :expected_count) do it 'ignores those records' do
::License::STARTER_PLAN | 2 expect(max_historical_user_count).to eq(0)
::License::PREMIUM_PLAN | 2
::License::ULTIMATE_PLAN | 1
end
with_them do
let(:plan) { gl_plan }
let(:current_license) do
create(:license, plan: plan, starts_at: Date.current - 1.month, expires_at: Date.current + 1.month)
end
it 'does not count guest users' do
expect(described_class.max_historical_user_count).to eq(expected_count)
end end
end end
end end
context 'with data outside of the license period' do context 'with data inside of the given period' do
context 'with stats before the license period' do
before do before do
described_class.create!(recorded_at: current_license.starts_at.ago(2.days), active_user_count: 10) create(:historical_data, recorded_at: from + 2.days, active_user_count: 10)
end create(:historical_data, recorded_at: from + 5.days, active_user_count: 15)
it 'ignore those records' do
expect(described_class.max_historical_user_count).to eq(0)
end
end
context 'with stats after the license period' do
before do
described_class.create!(recorded_at: current_license.expires_at.in(2.days), active_user_count: 10)
end
it 'ignore those records' do
expect(described_class.max_historical_user_count).to eq(0)
end
end
context 'with stats inside license period' do
before do
described_class.create!(recorded_at: current_license.starts_at.in(2.days), active_user_count: 10)
described_class.create!(recorded_at: current_license.starts_at.in(5.days), active_user_count: 15)
end end
it 'returns max value for active_user_count' do it 'returns max value for active_user_count' do
expect(described_class.max_historical_user_count).to eq(15) expect(max_historical_user_count).to eq(15)
end
end
end
end
describe '.in_license_term' do
let_it_be(:now) { DateTime.new(2014, 12, 15) }
let_it_be(:license) do
create_current_license(
starts_at: Date.new(2014, 7, 1),
expires_at: Date.new(2014, 12, 31)
)
end
before_all do
described_class.create!(recorded_at: license.starts_at - 1.day, active_user_count: 1)
described_class.create!(recorded_at: license.expires_at + 1.day, active_user_count: 2)
described_class.create!(recorded_at: now - 1.year - 1.day, active_user_count: 3)
described_class.create!(recorded_at: now + 1.day, active_user_count: 4)
end
around do |example|
travel_to(now) { example.run }
end
context 'with a license that has a start and end date' do
it 'returns correct number of records within the license range' do
expect(described_class.in_license_term(license).count).to eq(7)
end
end
context 'with a license that has no end date' do
let_it_be(:license) do
create_current_license(
starts_at: Date.new(2014, 7, 1),
expires_at: nil
)
end
it 'returns correct number of records within the past year' do
expect(described_class.in_license_term(license).count).to eq(6)
end end
end end
end end
......
...@@ -122,7 +122,7 @@ RSpec.describe License do ...@@ -122,7 +122,7 @@ RSpec.describe License do
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) { HistoricalData.create!(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
...@@ -303,7 +303,7 @@ RSpec.describe License do ...@@ -303,7 +303,7 @@ RSpec.describe License do
describe 'downgrade' do describe 'downgrade' do
context 'when more users were added in previous period' do context 'when more users were added in previous period' do
before do before do
HistoricalData.create!(recorded_at: described_class.current.starts_at - 6.months, active_user_count: 15) create(:historical_data, recorded_at: described_class.current.starts_at - 6.months, active_user_count: 15)
set_restrictions(restricted_user_count: 5, previous_user_count: 10) set_restrictions(restricted_user_count: 5, previous_user_count: 10)
end end
...@@ -315,7 +315,7 @@ RSpec.describe License do ...@@ -315,7 +315,7 @@ RSpec.describe License do
context 'when no users were added in the previous period' do context 'when no users were added in the previous period' do
before do before do
HistoricalData.create!(recorded_at: 6.months.ago, active_user_count: 15) create(:historical_data, recorded_at: 6.months.ago, active_user_count: 15)
set_restrictions(restricted_user_count: 10, previous_user_count: 15) set_restrictions(restricted_user_count: 10, previous_user_count: 15)
end end
...@@ -964,6 +964,150 @@ RSpec.describe License do ...@@ -964,6 +964,150 @@ RSpec.describe License do
end end
end end
describe '#historical_data' do
subject(:historical_data_count) { license.historical_data.count }
let_it_be(:now) { DateTime.new(2014, 12, 15) }
let_it_be(:license) { create(:license, starts_at: Date.new(2014, 7, 1), expires_at: Date.new(2014, 12, 31)) }
before_all do
(1..12).each do |i|
create(:historical_data, recorded_at: Date.new(2014, i, 1), active_user_count: i * 100)
end
create(:historical_data, recorded_at: license.starts_at - 1.day, active_user_count: 1)
create(:historical_data, recorded_at: license.expires_at + 1.day, active_user_count: 2)
create(:historical_data, recorded_at: now - 1.year - 1.day, active_user_count: 3)
create(:historical_data, recorded_at: now + 1.day, active_user_count: 4)
end
around do |example|
travel_to(now) { example.run }
end
context 'with using parameters' do
it 'returns correct number of records within the given range' do
from = Date.new(2014, 8, 1)
to = Date.new(2014, 11, 30)
expect(license.historical_data(from: from, to: to).count).to eq(4)
end
end
context 'with a license that has a start and end date' do
it 'returns correct number of records within the license range' do
expect(historical_data_count).to eq(7)
end
end
context 'with a license that has no start date' do
let_it_be(:license) { create(:license, starts_at: nil, expires_at: Date.new(2014, 12, 31)) }
it 'returns correct number of records starting a year ago to license\s expiration date' do
expect(historical_data_count).to eq(14)
end
end
context 'with a license that has no end date' do
let_it_be(:license) { create(:license, starts_at: Date.new(2014, 7, 1), expires_at: nil) }
it 'returns correct number of records from the license\'s start date to today' do
expect(historical_data_count).to eq(6)
end
end
end
describe '#historical_max' do
subject(:historical_max) { license.historical_max }
let(:license) { create(:license, starts_at: Date.current - 1.month, expires_at: Date.current + 1.month) }
context 'when using parameters' do
before do
(1..12).each do |i|
create(:historical_data, recorded_at: Date.new(2014, i, 1), active_user_count: i * 100)
end
end
it 'returns max user count for the given time range' do
from = Date.new(2014, 6, 1)
to = Date.new(2014, 9, 1)
expect(license.historical_max(from: from, to: to)).to eq(900)
end
end
context 'with different plans for the license' do
using RSpec::Parameterized::TableSyntax
where(:gl_plan, :expected_count) do
::License::STARTER_PLAN | 2
::License::PREMIUM_PLAN | 2
::License::ULTIMATE_PLAN | 1
end
with_them do
let(:plan) { gl_plan }
let(:license) do
create(:license, plan: plan, starts_at: Date.current - 1.month, expires_at: Date.current + 1.month)
end
before do
license
create(:group_member, :guest)
create(:group_member, :reporter)
HistoricalData.track!
end
it 'does not count guest users' do
expect(historical_max).to eq(expected_count)
end
end
end
context 'with data inside and outside of the license period' do
before do
create(:historical_data, recorded_at: license.starts_at.ago(2.days), active_user_count: 20)
create(:historical_data, recorded_at: license.starts_at.in(2.days), active_user_count: 10)
create(:historical_data, recorded_at: license.starts_at.in(5.days), active_user_count: 15)
create(:historical_data, recorded_at: license.expires_at.in(2.days), active_user_count: 25)
end
it 'returns max value for active_user_count for within the license period only' do
expect(historical_max).to eq(15)
end
end
context 'when license has no start date' do
let(:license) { create(:license, starts_at: nil, expires_at: Date.current + 1.month) }
before do
create(:historical_data, recorded_at: Date.yesterday.ago(1.year), active_user_count: 15)
create(:historical_data, recorded_at: Date.current.ago(1.year), active_user_count: 12)
create(:historical_data, recorded_at: license.expires_at.ago(2.days), active_user_count: 10)
end
it 'returns max value for active_user_count from up to a year ago' do
expect(historical_max).to eq(12)
end
end
context 'when license has no expiration date' do
let(:license) { create(:license, starts_at: Date.current.ago(1.month), expires_at: nil) }
before do
create(:historical_data, recorded_at: license.starts_at.in(2.days), active_user_count: 10)
create(:historical_data, recorded_at: Date.tomorrow, active_user_count: 15)
end
it 'returns max value for active_user_count until today' do
expect(historical_max).to eq(10)
end
end
end
describe '#maximum_user_count' do describe '#maximum_user_count' do
let(:now) { Date.current } let(:now) { Date.current }
......
...@@ -11,13 +11,13 @@ RSpec.describe SyncSeatLinkWorker, type: :worker do ...@@ -11,13 +11,13 @@ RSpec.describe SyncSeatLinkWorker, type: :worker do
# Setting the date as 12th March 2020 12:00 UTC for tests and creating new license # Setting the date as 12th March 2020 12:00 UTC for tests and creating new license
create_current_license(starts_at: '2020-02-12'.to_date) create_current_license(starts_at: '2020-02-12'.to_date)
HistoricalData.create!(recorded_at: '2020-02-11T00:00:00Z', active_user_count: 100) create(:historical_data, recorded_at: '2020-02-11T00:00:00Z', active_user_count: 100)
HistoricalData.create!(recorded_at: '2020-02-12T00:00:00Z', active_user_count: 10) create(:historical_data, recorded_at: '2020-02-12T00:00:00Z', active_user_count: 10)
HistoricalData.create!(recorded_at: '2020-02-13T00:00:00Z', active_user_count: 15) create(:historical_data, recorded_at: '2020-02-13T00:00:00Z', active_user_count: 15)
HistoricalData.create!(recorded_at: '2020-03-11T00:00:00Z', active_user_count: 10) create(:historical_data, recorded_at: '2020-03-11T00:00:00Z', active_user_count: 10)
HistoricalData.create!(recorded_at: '2020-03-12T00:00:00Z', active_user_count: 12) create(:historical_data, recorded_at: '2020-03-12T00:00:00Z', active_user_count: 12)
HistoricalData.create!(recorded_at: '2020-03-15T00:00:00Z', active_user_count: 25) create(:historical_data, recorded_at: '2020-03-15T00:00:00Z', active_user_count: 25)
allow(SyncSeatLinkRequestWorker).to receive(:perform_async).and_return(true) allow(SyncSeatLinkRequestWorker).to receive(:perform_async).and_return(true)
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