debian-mirror-gitlab/spec/features/admin/admin_settings_spec.rb

642 lines
22 KiB
Ruby
Raw Normal View History

2019-10-12 21:52:04 +05:30
# frozen_string_literal: true
2017-08-17 22:00:37 +05:30
require 'spec_helper'
2015-04-26 12:48:37 +05:30
2021-02-22 17:27:13 +05:30
RSpec.describe 'Admin updates settings' do
2017-08-17 22:00:37 +05:30
include StubENV
2018-10-15 14:42:47 +05:30
include TermsHelper
2020-06-23 00:09:42 +05:30
include UsageDataHelpers
2018-10-15 14:42:47 +05:30
let(:admin) { create(:admin) }
2017-08-17 22:00:37 +05:30
2020-03-13 15:44:24 +05:30
context 'feature flag :user_mode_in_session is enabled', :request_store do
2018-12-05 23:21:45 +05:30
before do
2019-12-21 20:55:43 +05:30
stub_env('IN_MEMORY_APPLICATION_SETTINGS', 'false')
sign_in(admin)
gitlab_enable_admin_mode_sign_in(admin)
2018-05-09 12:01:36 +05:30
end
2017-08-17 22:00:37 +05:30
2019-12-21 20:55:43 +05:30
context 'General page' do
2020-11-24 15:15:51 +05:30
let(:gitpod_feature_enabled) { true }
2019-12-21 20:55:43 +05:30
before do
2020-11-24 15:15:51 +05:30
stub_feature_flags(gitpod: gitpod_feature_enabled)
2019-12-21 20:55:43 +05:30
visit general_admin_application_settings_path
2018-12-05 23:21:45 +05:30
end
2017-08-17 22:00:37 +05:30
2021-02-22 17:27:13 +05:30
it 'change visibility settings' do
2019-12-21 20:55:43 +05:30
page.within('.as-visibility-access') do
choose "application_setting_default_project_visibility_20"
click_button 'Save changes'
end
2017-09-10 17:25:29 +05:30
2019-12-21 20:55:43 +05:30
expect(page).to have_content "Application settings saved successfully"
2018-12-05 23:21:45 +05:30
end
2017-09-10 17:25:29 +05:30
2021-02-22 17:27:13 +05:30
it 'uncheck all restricted visibility levels' do
2019-12-21 20:55:43 +05:30
page.within('.as-visibility-access') do
find('#application_setting_visibility_level_0').set(false)
find('#application_setting_visibility_level_10').set(false)
find('#application_setting_visibility_level_20').set(false)
click_button 'Save changes'
end
expect(page).to have_content "Application settings saved successfully"
expect(find('#application_setting_visibility_level_0')).not_to be_checked
expect(find('#application_setting_visibility_level_10')).not_to be_checked
expect(find('#application_setting_visibility_level_20')).not_to be_checked
end
2018-05-09 12:01:36 +05:30
2021-02-22 17:27:13 +05:30
it 'modify import sources' do
2019-12-21 20:55:43 +05:30
expect(current_settings.import_sources).not_to be_empty
2018-12-05 23:21:45 +05:30
2019-12-21 20:55:43 +05:30
page.within('.as-visibility-access') do
Gitlab::ImportSources.options.map do |name, _|
uncheck name
end
click_button 'Save changes'
2018-12-05 23:21:45 +05:30
end
2019-12-21 20:55:43 +05:30
expect(page).to have_content "Application settings saved successfully"
expect(current_settings.import_sources).to be_empty
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
page.within('.as-visibility-access') do
check "Repo by URL"
click_button 'Save changes'
end
2018-12-05 23:21:45 +05:30
2019-12-21 20:55:43 +05:30
expect(page).to have_content "Application settings saved successfully"
expect(current_settings.import_sources).to eq(['git'])
2018-12-05 23:21:45 +05:30
end
2021-02-22 17:27:13 +05:30
it 'change Visibility and Access Controls' do
2019-12-21 20:55:43 +05:30
page.within('.as-visibility-access') do
uncheck 'Project export enabled'
click_button 'Save changes'
end
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
expect(current_settings.project_export_enabled).to be_falsey
expect(page).to have_content "Application settings saved successfully"
2018-12-05 23:21:45 +05:30
end
2018-05-09 12:01:36 +05:30
2021-02-22 17:27:13 +05:30
it 'change Keys settings' do
2019-12-21 20:55:43 +05:30
page.within('.as-visibility-access') do
select 'Are forbidden', from: 'RSA SSH keys'
select 'Are allowed', from: 'DSA SSH keys'
select 'Must be at least 384 bits', from: 'ECDSA SSH keys'
select 'Are forbidden', from: 'ED25519 SSH keys'
click_on 'Save changes'
end
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
forbidden = ApplicationSetting::FORBIDDEN_KEY_VALUE.to_s
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
expect(page).to have_content 'Application settings saved successfully'
expect(find_field('RSA SSH keys').value).to eq(forbidden)
expect(find_field('DSA SSH keys').value).to eq('0')
expect(find_field('ECDSA SSH keys').value).to eq('384')
expect(find_field('ED25519 SSH keys').value).to eq(forbidden)
end
2018-12-05 23:21:45 +05:30
2021-02-22 17:27:13 +05:30
it 'change Account and Limit Settings' do
2019-12-21 20:55:43 +05:30
page.within('.as-account-limit') do
uncheck 'Gravatar enabled'
click_button 'Save changes'
end
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
expect(current_settings.gravatar_enabled).to be_falsey
expect(page).to have_content "Application settings saved successfully"
2018-12-05 23:21:45 +05:30
end
2018-05-09 12:01:36 +05:30
2021-02-22 17:27:13 +05:30
it 'change Maximum import size' do
2020-06-23 00:09:42 +05:30
page.within('.as-account-limit') do
fill_in 'Maximum import size (MB)', with: 15
click_button 'Save changes'
end
expect(current_settings.max_import_size).to eq 15
expect(page).to have_content "Application settings saved successfully"
end
2021-02-22 17:27:13 +05:30
it 'change New users set to external', :js do
2019-12-21 20:55:43 +05:30
user_internal_regex = find('#application_setting_user_default_internal_regex', visible: :all)
2015-04-26 12:48:37 +05:30
2019-12-21 20:55:43 +05:30
expect(user_internal_regex).to be_readonly
expect(user_internal_regex['placeholder']).to eq 'To define internal users, first enable new users set to external'
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
check 'application_setting_user_default_external'
2018-11-20 20:47:30 +05:30
2019-12-21 20:55:43 +05:30
expect(user_internal_regex).not_to be_readonly
expect(user_internal_regex['placeholder']).to eq 'Regex pattern'
end
2018-11-20 20:47:30 +05:30
2021-01-03 14:25:43 +05:30
context 'Change Sign-up restrictions' do
context 'Require Admin approval for new signup setting' do
2021-01-29 00:20:46 +05:30
it 'changes the setting' do
page.within('.as-signup') do
check 'Require admin approval for new sign-ups'
click_button 'Save changes'
2021-01-03 14:25:43 +05:30
end
2021-01-29 00:20:46 +05:30
expect(current_settings.require_admin_approval_after_user_signup).to be_truthy
expect(page).to have_content "Application settings saved successfully"
2021-01-03 14:25:43 +05:30
end
end
end
2021-02-22 17:27:13 +05:30
it 'change Sign-in restrictions' do
2019-12-21 20:55:43 +05:30
page.within('.as-signin') do
fill_in 'Home page URL', with: 'https://about.gitlab.com/'
click_button 'Save changes'
end
2018-11-20 20:47:30 +05:30
2019-12-21 20:55:43 +05:30
expect(current_settings.home_page_url).to eq "https://about.gitlab.com/"
expect(page).to have_content "Application settings saved successfully"
2018-12-05 23:21:45 +05:30
end
2018-11-20 20:47:30 +05:30
2021-02-22 17:27:13 +05:30
it 'terms of Service' do
2019-12-21 20:55:43 +05:30
# Already have the admin accept terms, so they don't need to accept in this spec.
_existing_terms = create(:term)
accept_terms(admin)
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
page.within('.as-terms') do
check 'Require all users to accept Terms of Service and Privacy Policy when they access GitLab.'
fill_in 'Terms of Service Agreement', with: 'Be nice!'
click_button 'Save changes'
end
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
expect(current_settings.enforce_terms).to be(true)
expect(current_settings.terms).to eq 'Be nice!'
expect(page).to have_content 'Application settings saved successfully'
2018-12-05 23:21:45 +05:30
end
2018-10-15 14:42:47 +05:30
2021-02-22 17:27:13 +05:30
it 'modify oauth providers' do
2019-12-21 20:55:43 +05:30
expect(current_settings.disabled_oauth_sign_in_sources).to be_empty
2018-10-15 14:42:47 +05:30
2019-12-21 20:55:43 +05:30
page.within('.as-signin') do
uncheck 'Google'
click_button 'Save changes'
end
2018-10-15 14:42:47 +05:30
2019-12-21 20:55:43 +05:30
expect(page).to have_content "Application settings saved successfully"
expect(current_settings.disabled_oauth_sign_in_sources).to include('google_oauth2')
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
page.within('.as-signin') do
check "Google"
click_button 'Save changes'
end
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
expect(page).to have_content "Application settings saved successfully"
expect(current_settings.disabled_oauth_sign_in_sources).not_to include('google_oauth2')
2018-12-05 23:21:45 +05:30
end
2018-05-09 12:01:36 +05:30
2021-02-22 17:27:13 +05:30
it 'oauth providers do not raise validation errors when saving unrelated changes' do
2019-12-21 20:55:43 +05:30
expect(current_settings.disabled_oauth_sign_in_sources).to be_empty
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
page.within('.as-signin') do
uncheck 'Google'
click_button 'Save changes'
end
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
expect(page).to have_content "Application settings saved successfully"
expect(current_settings.disabled_oauth_sign_in_sources).to include('google_oauth2')
2018-11-08 19:23:39 +05:30
2019-12-21 20:55:43 +05:30
# Remove google_oauth2 from the Omniauth strategies
allow(Devise).to receive(:omniauth_providers).and_return([])
2018-11-08 19:23:39 +05:30
2019-12-21 20:55:43 +05:30
# Save an unrelated setting
page.within('.as-terms') do
click_button 'Save changes'
end
2018-11-08 19:23:39 +05:30
2019-12-21 20:55:43 +05:30
expect(page).to have_content "Application settings saved successfully"
expect(current_settings.disabled_oauth_sign_in_sources).to include('google_oauth2')
2018-12-05 23:21:45 +05:30
end
2018-11-08 19:23:39 +05:30
2021-02-22 17:27:13 +05:30
it 'configure web terminal' do
2019-12-21 20:55:43 +05:30
page.within('.as-terminal') do
fill_in 'Max session time', with: 15
click_button 'Save changes'
end
expect(page).to have_content "Application settings saved successfully"
expect(current_settings.terminal_max_session_time).to eq(15)
end
2020-11-24 15:15:51 +05:30
context 'Configure Gitpod' do
context 'with feature disabled' do
let(:gitpod_feature_enabled) { false }
it 'do not show settings' do
expect(page).not_to have_selector('#js-gitpod-settings')
end
end
context 'with feature enabled' do
let(:gitpod_feature_enabled) { true }
it 'changes gitpod settings' do
page.within('#js-gitpod-settings') do
check 'Enable Gitpod integration'
fill_in 'Gitpod URL', with: 'https://gitpod.test/'
click_button 'Save changes'
end
expect(page).to have_content 'Application settings saved successfully'
expect(current_settings.gitpod_url).to eq('https://gitpod.test/')
expect(current_settings.gitpod_enabled).to be(true)
end
end
end
2018-11-08 19:23:39 +05:30
end
2019-12-21 20:55:43 +05:30
context 'Integrations page' do
before do
2020-10-24 23:57:45 +05:30
visit general_admin_application_settings_path
2018-12-05 23:21:45 +05:30
end
2018-11-08 19:23:39 +05:30
2021-02-22 17:27:13 +05:30
it 'enable hiding third party offers' do
2019-12-21 20:55:43 +05:30
page.within('.as-third-party-offers') do
check 'Do not display offers from third parties within GitLab'
click_button 'Save changes'
end
2018-03-17 18:26:18 +05:30
2019-12-21 20:55:43 +05:30
expect(page).to have_content "Application settings saved successfully"
expect(current_settings.hide_third_party_offers).to be true
end
2021-02-22 17:27:13 +05:30
it 'change Slack Notifications Service template settings', :js do
2019-12-21 20:55:43 +05:30
first(:link, 'Service Templates').click
click_link 'Slack notifications'
fill_in 'Webhook', with: 'http://localhost'
fill_in 'Username', with: 'test_user'
2020-05-24 23:13:21 +05:30
fill_in 'service[push_channel]', with: '#test_channel'
2019-12-21 20:55:43 +05:30
page.check('Notify only broken pipelines')
page.select 'All branches', from: 'Branches to be notified'
check_all_events
2020-11-24 15:15:51 +05:30
click_button 'Save changes'
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
expect(page).to have_content 'Application settings saved successfully'
click_link 'Slack notifications'
2020-03-13 15:44:24 +05:30
expect(page.all('input[type=checkbox]')).to all(be_checked)
2019-12-21 20:55:43 +05:30
expect(find_field('Webhook').value).to eq 'http://localhost'
expect(find_field('Username').value).to eq 'test_user'
2020-05-24 23:13:21 +05:30
expect(find('[name="service[push_channel]"]').value).to eq '#test_channel'
2018-12-05 23:21:45 +05:30
end
2018-05-09 12:01:36 +05:30
2020-05-24 23:13:21 +05:30
it 'defaults Deployment events to false for chat notification template settings', :js do
2019-12-21 20:55:43 +05:30
first(:link, 'Service Templates').click
click_link 'Slack notifications'
expect(find_field('Deployment')).not_to be_checked
end
2018-05-09 12:01:36 +05:30
end
2018-03-17 18:26:18 +05:30
2020-04-22 19:07:51 +05:30
context 'Integration page', :js do
before do
visit integrations_admin_application_settings_path
end
it 'allows user to dismiss deprecation notice' do
expect(page).to have_content('Some settings have moved')
click_button 'Dismiss'
wait_for_requests
expect(page).not_to have_content('Some settings have moved')
visit integrations_admin_application_settings_path
expect(page).not_to have_content('Some settings have moved')
end
end
2019-12-21 20:55:43 +05:30
context 'CI/CD page' do
2021-02-22 17:27:13 +05:30
it 'change CI/CD settings' do
2019-12-21 20:55:43 +05:30
visit ci_cd_admin_application_settings_path
page.within('.as-ci-cd') do
check 'Default to Auto DevOps pipeline for all projects'
fill_in 'application_setting_auto_devops_domain', with: 'domain.com'
click_button 'Save changes'
end
2015-04-26 12:48:37 +05:30
2019-12-21 20:55:43 +05:30
expect(current_settings.auto_devops_enabled?).to be true
expect(current_settings.auto_devops_domain).to eq('domain.com')
expect(page).to have_content "Application settings saved successfully"
end
2020-11-24 15:15:51 +05:30
context 'Container Registry' do
context 'delete tags service execution timeout' do
let(:feature_flag_enabled) { true }
let(:client_support) { true }
before do
stub_container_registry_config(enabled: true)
stub_feature_flags(container_registry_expiration_policies_throttling: feature_flag_enabled)
allow(ContainerRegistry::Client).to receive(:supports_tag_delete?).and_return(client_support)
end
RSpec.shared_examples 'not having service timeout settings' do
it 'lacks the timeout settings' do
visit ci_cd_admin_application_settings_path
expect(page).not_to have_content "Container Registry delete tags service execution timeout"
end
end
context 'with feature flag enabled' do
context 'with client supporting tag delete' do
it 'changes the timeout' do
visit ci_cd_admin_application_settings_path
page.within('.as-registry') do
fill_in 'application_setting_container_registry_delete_tags_service_timeout', with: 400
click_button 'Save changes'
end
expect(current_settings.container_registry_delete_tags_service_timeout).to eq(400)
expect(page).to have_content "Application settings saved successfully"
end
end
context 'with client not supporting tag delete' do
let(:client_support) { false }
it_behaves_like 'not having service timeout settings'
end
end
context 'with feature flag disabled' do
let(:feature_flag_enabled) { false }
it_behaves_like 'not having service timeout settings'
end
end
end
2019-12-21 20:55:43 +05:30
end
2018-05-09 12:01:36 +05:30
2020-06-23 00:09:42 +05:30
context 'Repository page' do
2021-02-22 17:27:13 +05:30
it 'change Repository storage settings' do
2020-06-23 00:09:42 +05:30
visit repository_admin_application_settings_path
page.within('.as-repository-storage') do
fill_in 'application_setting_repository_storages_weighted_default', with: 50
click_button 'Save changes'
end
expect(current_settings.repository_storages_weighted_default).to be 50
end
end
2019-12-21 20:55:43 +05:30
context 'Reporting page' do
2021-02-22 17:27:13 +05:30
it 'change Spam settings' do
2019-12-21 20:55:43 +05:30
visit reporting_admin_application_settings_path
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
page.within('.as-spam') do
fill_in 'reCAPTCHA Site Key', with: 'key'
fill_in 'reCAPTCHA Private Key', with: 'key'
2020-06-23 00:09:42 +05:30
check 'Enable reCAPTCHA'
check 'Enable reCAPTCHA for login'
2019-12-21 20:55:43 +05:30
fill_in 'IPs per user', with: 15
2020-06-23 00:09:42 +05:30
check 'Enable Spam Check via external API endpoint'
fill_in 'URL of the external Spam Check endpoint', with: 'https://www.example.com/spamcheck'
2019-12-21 20:55:43 +05:30
click_button 'Save changes'
end
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
expect(page).to have_content "Application settings saved successfully"
expect(current_settings.recaptcha_enabled).to be true
expect(current_settings.login_recaptcha_protection_enabled).to be true
expect(current_settings.unique_ips_limit_per_user).to eq(15)
2020-06-23 00:09:42 +05:30
expect(current_settings.spam_check_endpoint_enabled).to be true
expect(current_settings.spam_check_endpoint_url).to eq 'https://www.example.com/spamcheck'
2018-12-05 23:21:45 +05:30
end
end
2019-07-31 22:56:46 +05:30
2019-12-21 20:55:43 +05:30
context 'Metrics and profiling page' do
before do
visit metrics_and_profiling_admin_application_settings_path
end
2019-07-31 22:56:46 +05:30
2021-02-22 17:27:13 +05:30
it 'change Prometheus settings' do
2019-12-21 20:55:43 +05:30
page.within('.as-prometheus') do
check 'Enable Prometheus Metrics'
click_button 'Save changes'
end
2018-12-05 23:21:45 +05:30
2019-12-21 20:55:43 +05:30
expect(current_settings.prometheus_metrics_enabled?).to be true
expect(page).to have_content "Application settings saved successfully"
2018-12-05 23:21:45 +05:30
end
2018-05-09 12:01:36 +05:30
2021-02-22 17:27:13 +05:30
it 'change Performance bar settings' do
2019-12-21 20:55:43 +05:30
group = create(:group)
page.within('.as-performance-bar') do
check 'Enable access to the Performance Bar'
fill_in 'Allowed group', with: group.path
click_on 'Save changes'
end
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
expect(page).to have_content "Application settings saved successfully"
expect(find_field('Enable access to the Performance Bar')).to be_checked
expect(find_field('Allowed group').value).to eq group.path
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
page.within('.as-performance-bar') do
uncheck 'Enable access to the Performance Bar'
click_on 'Save changes'
end
expect(page).to have_content 'Application settings saved successfully'
expect(find_field('Enable access to the Performance Bar')).not_to be_checked
expect(find_field('Allowed group').value).to be_nil
2018-12-05 23:21:45 +05:30
end
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
it 'loads usage ping payload on click', :js do
2020-06-23 00:09:42 +05:30
stub_usage_data_connections
2020-03-13 15:44:24 +05:30
2020-04-22 19:07:51 +05:30
page.within('#js-usage-settings') do
expected_payload_content = /(?=.*"uuid")(?=.*"hostname")/m
2018-05-09 12:01:36 +05:30
2020-04-22 19:07:51 +05:30
expect(page).not_to have_content expected_payload_content
2018-05-09 12:01:36 +05:30
2020-04-22 19:07:51 +05:30
click_button('Preview payload')
wait_for_requests
expect(page).to have_selector '.js-usage-ping-payload'
expect(page).to have_button 'Hide payload'
expect(page).to have_content expected_payload_content
end
2018-12-05 23:21:45 +05:30
end
2019-12-21 20:55:43 +05:30
end
context 'Network page' do
2021-02-22 17:27:13 +05:30
it 'changes Outbound requests settings' do
2019-12-21 20:55:43 +05:30
visit network_admin_application_settings_path
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
page.within('.as-outbound') do
check 'Allow requests to the local network from web hooks and services'
# Enabled by default
uncheck 'Allow requests to the local network from system hooks'
# Enabled by default
uncheck 'Enforce DNS rebinding attack protection'
click_button 'Save changes'
end
expect(page).to have_content "Application settings saved successfully"
expect(current_settings.allow_local_requests_from_web_hooks_and_services).to be true
expect(current_settings.allow_local_requests_from_system_hooks).to be false
expect(current_settings.dns_rebinding_protection_enabled).to be false
end
2020-05-24 23:13:21 +05:30
2021-02-22 17:27:13 +05:30
it 'changes Issues rate limits settings' do
2020-05-24 23:13:21 +05:30
visit network_admin_application_settings_path
page.within('.as-issue-limits') do
2020-06-23 00:09:42 +05:30
fill_in 'Max requests per minute per user', with: 0
2020-05-24 23:13:21 +05:30
click_button 'Save changes'
end
expect(page).to have_content "Application settings saved successfully"
expect(current_settings.issues_create_limit).to eq(0)
end
2018-05-09 12:01:36 +05:30
end
2019-12-21 20:55:43 +05:30
context 'Preferences page' do
before do
visit preferences_admin_application_settings_path
2018-12-05 23:21:45 +05:30
end
2018-05-09 12:01:36 +05:30
2021-02-22 17:27:13 +05:30
it 'change Help page' do
2021-01-03 14:25:43 +05:30
stub_feature_flags(help_page_documentation_redirect: true)
2019-12-21 20:55:43 +05:30
new_support_url = 'http://example.com/help'
2021-01-03 14:25:43 +05:30
new_documentation_url = 'https://docs.gitlab.com'
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
page.within('.as-help-page') do
fill_in 'Help page text', with: 'Example text'
check 'Hide marketing-related entries from help'
fill_in 'Support page URL', with: new_support_url
2021-01-03 14:25:43 +05:30
fill_in 'Documentation pages URL', with: new_documentation_url
2019-12-21 20:55:43 +05:30
click_button 'Save changes'
end
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
expect(current_settings.help_page_text).to eq "Example text"
expect(current_settings.help_page_hide_commercial_content).to be_truthy
expect(current_settings.help_page_support_url).to eq new_support_url
2021-01-03 14:25:43 +05:30
expect(current_settings.help_page_documentation_base_url).to eq new_documentation_url
2019-12-21 20:55:43 +05:30
expect(page).to have_content "Application settings saved successfully"
2018-12-05 23:21:45 +05:30
end
2018-05-09 12:01:36 +05:30
2021-02-22 17:27:13 +05:30
it 'change Pages settings' do
2019-12-21 20:55:43 +05:30
page.within('.as-pages') do
fill_in 'Maximum size of pages (MB)', with: 15
check 'Require users to prove ownership of custom domains'
click_button 'Save changes'
end
2018-05-09 12:01:36 +05:30
2019-12-21 20:55:43 +05:30
expect(current_settings.max_pages_size).to eq 15
expect(current_settings.pages_domain_verification_enabled?).to be_truthy
expect(page).to have_content "Application settings saved successfully"
2018-12-05 23:21:45 +05:30
end
2021-02-22 17:27:13 +05:30
it 'change Real-time features settings' do
2019-12-21 20:55:43 +05:30
page.within('.as-realtime') do
fill_in 'Polling interval multiplier', with: 5.0
click_button 'Save changes'
end
2018-11-08 19:23:39 +05:30
2019-12-21 20:55:43 +05:30
expect(current_settings.polling_interval_multiplier).to eq 5.0
expect(page).to have_content "Application settings saved successfully"
end
2018-11-08 19:23:39 +05:30
2019-12-21 20:55:43 +05:30
it 'shows an error when validation fails' do
page.within('.as-realtime') do
fill_in 'Polling interval multiplier', with: -1.0
click_button 'Save changes'
end
2017-08-17 22:00:37 +05:30
2019-12-21 20:55:43 +05:30
expect(current_settings.polling_interval_multiplier).not_to eq(-1.0)
expect(page)
.to have_content "The form contains the following error: Polling interval multiplier must be greater than or equal to 0"
end
2015-09-11 14:41:01 +05:30
2021-02-22 17:27:13 +05:30
it "change Pages Let's Encrypt settings" do
2019-12-21 20:55:43 +05:30
visit preferences_admin_application_settings_path
page.within('.as-pages') do
fill_in 'Email', with: 'my@test.example.com'
check "I have read and agree to the Let's Encrypt Terms of Service"
click_button 'Save changes'
end
2015-04-26 12:48:37 +05:30
2019-12-21 20:55:43 +05:30
expect(current_settings.lets_encrypt_notification_email).to eq 'my@test.example.com'
expect(current_settings.lets_encrypt_terms_of_service_accepted).to eq true
2018-12-05 23:21:45 +05:30
end
2015-04-26 12:48:37 +05:30
end
2017-08-17 22:00:37 +05:30
2019-12-21 20:55:43 +05:30
context 'Nav bar' do
2021-02-22 17:27:13 +05:30
it 'shows default help links in nav' do
2019-12-21 20:55:43 +05:30
default_support_url = 'https://about.gitlab.com/getting-help/'
2018-03-17 18:26:18 +05:30
2019-12-21 20:55:43 +05:30
visit root_dashboard_path
2019-10-12 21:52:04 +05:30
2019-12-21 20:55:43 +05:30
find('.header-help-dropdown-toggle').click
page.within '.header-help' do
expect(page).to have_link(text: 'Help', href: help_path)
expect(page).to have_link(text: 'Support', href: default_support_url)
end
2018-12-05 23:21:45 +05:30
end
2018-03-17 18:26:18 +05:30
2021-02-22 17:27:13 +05:30
it 'shows custom support url in nav when set' do
2019-12-21 20:55:43 +05:30
new_support_url = 'http://example.com/help'
stub_application_setting(help_page_support_url: new_support_url)
2018-11-20 20:47:30 +05:30
2019-12-21 20:55:43 +05:30
visit root_dashboard_path
2018-11-20 20:47:30 +05:30
2019-12-21 20:55:43 +05:30
find('.header-help-dropdown-toggle').click
page.within '.header-help' do
expect(page).to have_link(text: 'Support', href: new_support_url)
end
end
2019-10-12 21:52:04 +05:30
end
2019-12-21 20:55:43 +05:30
end
2019-10-12 21:52:04 +05:30
2019-12-21 20:55:43 +05:30
context 'feature flag :user_mode_in_session is disabled' do
before do
stub_feature_flags(user_mode_in_session: false)
2019-10-12 21:52:04 +05:30
2019-12-21 20:55:43 +05:30
stub_env('IN_MEMORY_APPLICATION_SETTINGS', 'false')
2019-10-12 21:52:04 +05:30
2019-12-21 20:55:43 +05:30
sign_in(admin)
2020-03-13 15:44:24 +05:30
visit general_admin_application_settings_path
2019-12-21 20:55:43 +05:30
end
it 'loads admin settings page without redirect for reauthentication' do
2020-03-13 15:44:24 +05:30
expect(current_path).to eq general_admin_application_settings_path
2019-10-12 21:52:04 +05:30
end
end
2017-08-17 22:00:37 +05:30
def check_all_events
2020-11-24 15:15:51 +05:30
page.check('Active')
2017-08-17 22:00:37 +05:30
page.check('Push')
page.check('Issue')
2020-05-24 23:13:21 +05:30
page.check('Confidential Issue')
page.check('Merge Request')
2019-07-31 22:56:46 +05:30
page.check('Note')
2020-05-24 23:13:21 +05:30
page.check('Confidential Note')
page.check('Tag Push')
2017-08-17 22:00:37 +05:30
page.check('Pipeline')
2020-05-24 23:13:21 +05:30
page.check('Wiki Page')
2019-07-31 22:56:46 +05:30
page.check('Deployment')
2017-08-17 22:00:37 +05:30
end
2019-09-30 21:07:59 +05:30
def current_settings
ApplicationSetting.current_without_cache
end
2015-04-26 12:48:37 +05:30
end