147 lines
4.5 KiB
Ruby
147 lines
4.5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require 'spec_helper'
|
|
|
|
RSpec.describe 'User sees feature flag list', :js do
|
|
include FeatureFlagHelpers
|
|
|
|
let_it_be(:user) { create(:user) }
|
|
let_it_be(:project) { create(:project, namespace: user.namespace) }
|
|
|
|
before_all do
|
|
project.add_developer(user)
|
|
end
|
|
|
|
before do
|
|
sign_in(user)
|
|
end
|
|
|
|
context 'with legacy feature flags' do
|
|
before do
|
|
create_flag(project, 'ci_live_trace', false).tap do |feature_flag|
|
|
create_scope(feature_flag, 'review/*', true)
|
|
end
|
|
create_flag(project, 'drop_legacy_artifacts', false)
|
|
create_flag(project, 'mr_train', true).tap do |feature_flag|
|
|
create_scope(feature_flag, 'production', false)
|
|
end
|
|
stub_feature_flags(feature_flags_legacy_read_only_override: false)
|
|
end
|
|
|
|
it 'user sees the first flag' do
|
|
visit(project_feature_flags_path(project))
|
|
|
|
within_feature_flag_row(1) do
|
|
expect(page.find('.js-feature-flag-id')).to have_content('^1')
|
|
expect(page.find('.feature-flag-name')).to have_content('ci_live_trace')
|
|
expect_status_toggle_button_not_to_be_checked
|
|
|
|
within_feature_flag_scopes do
|
|
expect(page.find('[data-qa-selector="feature-flag-scope-muted-badge"]:nth-child(1)')).to have_content('*')
|
|
expect(page.find('[data-qa-selector="feature-flag-scope-info-badge"]:nth-child(2)')).to have_content('review/*')
|
|
end
|
|
end
|
|
end
|
|
|
|
it 'user sees the second flag' do
|
|
visit(project_feature_flags_path(project))
|
|
|
|
within_feature_flag_row(2) do
|
|
expect(page.find('.js-feature-flag-id')).to have_content('^2')
|
|
expect(page.find('.feature-flag-name')).to have_content('drop_legacy_artifacts')
|
|
expect_status_toggle_button_not_to_be_checked
|
|
|
|
within_feature_flag_scopes do
|
|
expect(page.find('[data-qa-selector="feature-flag-scope-muted-badge"]:nth-child(1)')).to have_content('*')
|
|
end
|
|
end
|
|
end
|
|
|
|
it 'user sees the third flag' do
|
|
visit(project_feature_flags_path(project))
|
|
|
|
within_feature_flag_row(3) do
|
|
expect(page.find('.js-feature-flag-id')).to have_content('^3')
|
|
expect(page.find('.feature-flag-name')).to have_content('mr_train')
|
|
expect_status_toggle_button_to_be_checked
|
|
|
|
within_feature_flag_scopes do
|
|
expect(page.find('[data-qa-selector="feature-flag-scope-info-badge"]:nth-child(1)')).to have_content('*')
|
|
expect(page.find('[data-qa-selector="feature-flag-scope-muted-badge"]:nth-child(2)')).to have_content('production')
|
|
end
|
|
end
|
|
end
|
|
|
|
it 'user sees the status toggle disabled' do
|
|
visit(project_feature_flags_path(project))
|
|
|
|
within_feature_flag_row(1) do
|
|
expect_status_toggle_button_to_be_disabled
|
|
end
|
|
end
|
|
|
|
context 'when legacy feature flags are not read-only' do
|
|
before do
|
|
stub_feature_flags(feature_flags_legacy_read_only: false)
|
|
end
|
|
|
|
it 'user updates the status toggle' do
|
|
visit(project_feature_flags_path(project))
|
|
|
|
within_feature_flag_row(1) do
|
|
status_toggle_button.click
|
|
|
|
expect_status_toggle_button_to_be_checked
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'when legacy feature flags are read-only but the override is active for a project' do
|
|
before do
|
|
stub_feature_flags(
|
|
feature_flags_legacy_read_only: true,
|
|
feature_flags_legacy_read_only_override: project
|
|
)
|
|
end
|
|
|
|
it 'user updates the status toggle' do
|
|
visit(project_feature_flags_path(project))
|
|
|
|
within_feature_flag_row(1) do
|
|
status_toggle_button.click
|
|
|
|
expect_status_toggle_button_to_be_checked
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'with new version flags' do
|
|
before do
|
|
create(:operations_feature_flag, :new_version_flag, project: project,
|
|
name: 'my_flag', active: false)
|
|
end
|
|
|
|
it 'user updates the status toggle' do
|
|
visit(project_feature_flags_path(project))
|
|
|
|
within_feature_flag_row(1) do
|
|
status_toggle_button.click
|
|
|
|
expect_status_toggle_button_to_be_checked
|
|
end
|
|
end
|
|
end
|
|
|
|
context 'when there are no feature flags' do
|
|
before do
|
|
visit(project_feature_flags_path(project))
|
|
end
|
|
|
|
it 'shows empty page' do
|
|
expect(page).to have_text 'Get started with feature flags'
|
|
expect(page).to have_selector('.btn-success', text: 'New feature flag')
|
|
expect(page).to have_selector('[data-qa-selector="configure_feature_flags_button"]', text: 'Configure')
|
|
end
|
|
end
|
|
end
|