debian-mirror-gitlab/spec/models/operations/feature_flag_spec.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

169 lines
5.4 KiB
Ruby
Raw Normal View History

2020-11-24 15:15:51 +05:30
# frozen_string_literal: true
require 'spec_helper'
RSpec.describe Operations::FeatureFlag do
include FeatureFlagHelpers
subject { create(:operations_feature_flag) }
it_behaves_like 'includes Limitable concern' do
subject { build(:operations_feature_flag, project: create(:project)) }
end
describe 'associations' do
it { is_expected.to belong_to(:project) }
2021-11-18 22:05:49 +05:30
it { is_expected.to have_many(:strategies) }
2020-11-24 15:15:51 +05:30
end
2023-01-13 00:05:48 +05:30
describe 'default values' do
it { expect(described_class.new).to be_active }
it { expect(described_class.new.version).to eq('new_version_flag') }
end
2021-03-11 19:13:27 +05:30
describe '.reference_pattern' do
subject { described_class.reference_pattern }
it { is_expected.to match('[feature_flag:123]') }
it { is_expected.to match('[feature_flag:gitlab-org/gitlab/123]') }
end
describe '.link_reference_pattern' do
subject { described_class.link_reference_pattern }
it { is_expected.to match("#{Gitlab.config.gitlab.url}/gitlab-org/gitlab/-/feature_flags/123/edit") }
it { is_expected.not_to match("#{Gitlab.config.gitlab.url}/gitlab-org/gitlab/issues/123/edit") }
it { is_expected.not_to match("gitlab-org/gitlab/-/feature_flags/123/edit") }
end
describe '#to_reference' do
2023-07-09 08:55:56 +05:30
let(:namespace) { build(:namespace) }
let(:project) { build(:project, namespace: namespace) }
2021-03-11 19:13:27 +05:30
let(:feature_flag) { build(:operations_feature_flag, iid: 1, project: project) }
it 'returns feature flag id' do
expect(feature_flag.to_reference).to eq '[feature_flag:1]'
end
it 'returns complete path to the feature flag with full: true' do
2023-07-09 08:55:56 +05:30
expect(feature_flag.to_reference(full: true)).to eq "[feature_flag:#{project.full_path}/1]"
2021-03-11 19:13:27 +05:30
end
end
2020-11-24 15:15:51 +05:30
describe 'validations' do
it { is_expected.to validate_presence_of(:project) }
it { is_expected.to validate_presence_of(:name) }
it { is_expected.to validate_uniqueness_of(:name).scoped_to(:project_id) }
2021-11-11 11:23:49 +05:30
it { is_expected.to define_enum_for(:version).with_values(new_version_flag: 2) }
2020-11-24 15:15:51 +05:30
context 'a version 2 feature flag' do
it 'is valid if associated with Operations::FeatureFlags::Strategy models' do
project = create(:project)
2021-01-03 14:25:43 +05:30
feature_flag = described_class.create!({ name: 'test', project: project, version: 2,
2022-10-11 01:57:18 +05:30
strategies_attributes: [{ name: 'default', parameters: {} }] })
2020-11-24 15:15:51 +05:30
expect(feature_flag).to be_valid
end
end
it_behaves_like 'AtomicInternalId', validate_presence: true do
let(:internal_id_attribute) { :iid }
let(:instance) { build(:operations_feature_flag) }
let(:scope) { :project }
let(:scope_attrs) { { project: instance.project } }
let(:usage) { :operations_feature_flags }
end
end
describe '.enabled' do
subject { described_class.enabled }
context 'when the feature flag is active' do
let!(:feature_flag) { create(:operations_feature_flag, active: true) }
it 'returns the flag' do
is_expected.to eq([feature_flag])
end
end
context 'when the feature flag is inactive' do
let!(:feature_flag) { create(:operations_feature_flag, active: false) }
it 'does not return the flag' do
is_expected.to be_empty
end
end
end
describe '.disabled' do
subject { described_class.disabled }
context 'when the feature flag is active' do
let!(:feature_flag) { create(:operations_feature_flag, active: true) }
it 'does not return the flag' do
is_expected.to be_empty
end
end
context 'when the feature flag is inactive' do
let!(:feature_flag) { create(:operations_feature_flag, active: false) }
it 'returns the flag' do
is_expected.to eq([feature_flag])
end
end
end
describe '.for_unleash_client' do
let_it_be(:project) { create(:project) }
2021-09-30 23:02:18 +05:30
2020-11-24 15:15:51 +05:30
let!(:feature_flag) do
2022-10-11 01:57:18 +05:30
create(:operations_feature_flag, project: project, name: 'feature1', active: true, version: 2)
2020-11-24 15:15:51 +05:30
end
let!(:strategy) do
2022-10-11 01:57:18 +05:30
create(:operations_strategy, feature_flag: feature_flag, name: 'default', parameters: {})
2020-11-24 15:15:51 +05:30
end
it 'matches wild cards in the scope' do
create(:operations_scope, strategy: strategy, environment_scope: 'review/*')
flags = described_class.for_unleash_client(project, 'review/feature-branch')
expect(flags).to eq([feature_flag])
end
it 'matches wild cards case sensitively' do
create(:operations_scope, strategy: strategy, environment_scope: 'Staging/*')
flags = described_class.for_unleash_client(project, 'staging/feature')
expect(flags).to eq([])
end
it 'returns feature flags ordered by id' do
create(:operations_scope, strategy: strategy, environment_scope: 'production')
2022-10-11 01:57:18 +05:30
feature_flag_b = create(:operations_feature_flag, project: project, name: 'feature2', active: true, version: 2)
strategy_b = create(:operations_strategy, feature_flag: feature_flag_b, name: 'default', parameters: {})
2020-11-24 15:15:51 +05:30
create(:operations_scope, strategy: strategy_b, environment_scope: '*')
flags = described_class.for_unleash_client(project, 'production')
expect(flags.map(&:id)).to eq([feature_flag.id, feature_flag_b.id])
end
end
2021-01-29 00:20:46 +05:30
describe '#hook_attrs' do
it 'includes expected attributes' do
hook_attrs = {
id: subject.id,
name: subject.name,
description: subject.description,
active: subject.active
}
expect(subject.hook_attrs).to eq(hook_attrs)
end
end
2020-11-24 15:15:51 +05:30
end