debian-mirror-gitlab/spec/models/concerns/counter_attribute_spec.rb
2023-03-17 16:20:25 +05:30

121 lines
3.8 KiB
Ruby

# frozen_string_literal: true
require 'spec_helper'
RSpec.describe CounterAttribute, :counter_attribute, :clean_gitlab_redis_shared_state do
using RSpec::Parameterized::TableSyntax
let(:project_statistics) { create(:project_statistics) }
let(:model) { CounterAttributeModel.find(project_statistics.id) }
it_behaves_like CounterAttribute, [:build_artifacts_size, :commit_count, :packages_size] do
let(:model) { CounterAttributeModel.find(project_statistics.id) }
end
describe '#counter_attribute_enabled?' do
it 'is true when counter attribute is defined' do
expect(project_statistics.counter_attribute_enabled?(:build_artifacts_size))
.to be_truthy
end
it 'is false when counter attribute is not defined' do
expect(model.counter_attribute_enabled?(:nope)).to be_falsey
end
context 'with a conditional counter attribute' do
[true, false].each do |enabled|
context "where the condition evaluates to #{enabled}" do
subject { model.counter_attribute_enabled?(:packages_size) }
before do
model.allow_package_size_counter = enabled
end
it { is_expected.to eq(enabled) }
end
end
end
end
describe '#initiate_refresh!' do
context 'when counter attribute is enabled' do
let(:attribute) { :build_artifacts_size }
it 'initiates refresh on the BufferedCounter' do
expect_next_instance_of(Gitlab::Counters::BufferedCounter, model, attribute) do |counter|
expect(counter).to receive(:initiate_refresh!)
end
model.initiate_refresh!(attribute)
end
end
context 'when counter attribute is not enabled' do
let(:attribute) { :snippets_size }
it 'raises error' do
expect { model.initiate_refresh!(attribute) }.to raise_error(ArgumentError)
end
end
end
describe '#finalize_refresh' do
let(:attribute) { :build_artifacts_size }
context 'when counter attribute is enabled' do
it 'initiates refresh on the BufferedCounter' do
expect_next_instance_of(Gitlab::Counters::BufferedCounter, model, attribute) do |counter|
expect(counter).to receive(:finalize_refresh)
end
model.finalize_refresh(attribute)
end
end
context 'when counter attribute is not enabled' do
let(:attribute) { :snippets_size }
it 'raises error' do
expect { model.finalize_refresh(attribute) }.to raise_error(ArgumentError)
end
end
end
describe '#counter' do
using RSpec::Parameterized::TableSyntax
it 'returns the counter for the respective attribute' do
expect(model.counter(:build_artifacts_size).send(:attribute)).to eq(:build_artifacts_size)
expect(model.counter(:commit_count).send(:attribute)).to eq(:commit_count)
end
it 'returns the appropriate counter for the attribute' do
expect(model.counter(:build_artifacts_size).class).to eq(Gitlab::Counters::BufferedCounter)
expect(model.counter(:packages_size).class).to eq(Gitlab::Counters::BufferedCounter)
expect(model.counter(:wiki_size).class).to eq(Gitlab::Counters::LegacyCounter)
end
context 'with a conditional counter attribute' do
where(:enabled, :expected_counter_class) do
[
[true, Gitlab::Counters::BufferedCounter],
[false, Gitlab::Counters::LegacyCounter]
]
end
with_them do
before do
model.allow_package_size_counter = enabled
end
it 'returns the appropriate counter based on the condition' do
expect(model.counter(:packages_size).class).to eq(expected_counter_class)
end
end
end
it 'raises error for unknown attribute' do
expect { model.counter(:unknown) }.to raise_error(ArgumentError, 'attribute "unknown" does not exist')
end
end
end