debian-mirror-gitlab/spec/migrations/change_public_projects_cost_factor_spec.rb
2023-03-04 22:38:38 +05:30

60 lines
2.1 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
require_migration!
RSpec.describe ChangePublicProjectsCostFactor, migration: :gitlab_ci, feature_category: :runner do
let(:runners) { table(:ci_runners) }
let!(:shared_1) { runners.create!(runner_type: 1, public_projects_minutes_cost_factor: 0) }
let!(:shared_2) { runners.create!(runner_type: 1, public_projects_minutes_cost_factor: 0) }
let!(:shared_3) { runners.create!(runner_type: 1, public_projects_minutes_cost_factor: 1) }
let!(:group_1) { runners.create!(runner_type: 2, public_projects_minutes_cost_factor: 0) }
describe '#up' do
context 'when on SaaS' do
before do
allow(Gitlab).to receive(:com?).and_return(true)
end
it 'updates the cost factor from 0 only for shared runners', :aggregate_failures do
migrate!
expect(shared_1.reload.public_projects_minutes_cost_factor).to eq(0.008)
expect(shared_2.reload.public_projects_minutes_cost_factor).to eq(0.008)
expect(shared_3.reload.public_projects_minutes_cost_factor).to eq(1)
expect(group_1.reload.public_projects_minutes_cost_factor).to eq(0)
end
end
context 'when on self-managed', :aggregate_failures do
it 'skips the migration' do
migrate!
expect(shared_1.public_projects_minutes_cost_factor).to eq(0)
expect(shared_2.public_projects_minutes_cost_factor).to eq(0)
expect(shared_3.public_projects_minutes_cost_factor).to eq(1)
expect(group_1.public_projects_minutes_cost_factor).to eq(0)
end
end
end
describe '#down' do
context 'when on SaaS' do
before do
allow(Gitlab).to receive(:com?).and_return(true)
end
it 'resets the cost factor to 0 only for shared runners that were updated', :aggregate_failures do
migrate!
schema_migrate_down!
expect(shared_1.public_projects_minutes_cost_factor).to eq(0)
expect(shared_2.public_projects_minutes_cost_factor).to eq(0)
expect(shared_3.public_projects_minutes_cost_factor).to eq(1)
expect(group_1.public_projects_minutes_cost_factor).to eq(0)
end
end
end
end