Commit 0df11843 authored by Martin Wortschack's avatar Martin Wortschack

Groups test cases by context

parent a7071ded
...@@ -11,385 +11,373 @@ describe 'Admin updates settings' do ...@@ -11,385 +11,373 @@ describe 'Admin updates settings' do
sign_in(admin) sign_in(admin)
end end
it 'Change visibility settings' do context 'General page' do
visit admin_application_settings_path before do
visit admin_application_settings_path
page.within('.as-visibility-access') do
choose "application_setting_default_project_visibility_20"
click_button 'Save changes'
end end
expect(page).to have_content "Application settings saved successfully" it 'Change visibility settings' do
end page.within('.as-visibility-access') do
choose "application_setting_default_project_visibility_20"
it 'Uncheck all restricted visibility levels' do click_button 'Save changes'
visit admin_application_settings_path end
page.within('.as-visibility-access') do expect(page).to have_content "Application settings saved successfully"
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 end
expect(page).to have_content "Application settings saved successfully" it 'Uncheck all restricted visibility levels' do
expect(find('#application_setting_visibility_level_0')).not_to be_checked page.within('.as-visibility-access') do
expect(find('#application_setting_visibility_level_10')).not_to be_checked find('#application_setting_visibility_level_0').set(false)
expect(find('#application_setting_visibility_level_20')).not_to be_checked find('#application_setting_visibility_level_10').set(false)
end 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
it 'Modify import sources' do it 'Modify import sources' do
visit admin_application_settings_path expect(Gitlab::CurrentSettings.import_sources).not_to be_empty
expect(Gitlab::CurrentSettings.import_sources).not_to be_empty page.within('.as-visibility-access') do
Gitlab::ImportSources.options.map do |name, _|
uncheck name
end
page.within('.as-visibility-access') do click_button 'Save changes'
Gitlab::ImportSources.options.map do |name, _|
uncheck name
end end
click_button 'Save changes' expect(page).to have_content "Application settings saved successfully"
end expect(Gitlab::CurrentSettings.import_sources).to be_empty
expect(page).to have_content "Application settings saved successfully" page.within('.as-visibility-access') do
expect(Gitlab::CurrentSettings.import_sources).to be_empty check "Repo by URL"
click_button 'Save changes'
end
page.within('.as-visibility-access') do expect(page).to have_content "Application settings saved successfully"
check "Repo by URL" expect(Gitlab::CurrentSettings.import_sources).to eq(['git'])
click_button 'Save changes'
end end
expect(page).to have_content "Application settings saved successfully" it 'Change Visibility and Access Controls' do
expect(Gitlab::CurrentSettings.import_sources).to eq(['git']) page.within('.as-visibility-access') do
end uncheck 'Project export enabled'
click_button 'Save changes'
it 'Change Visibility and Access Controls' do end
visit admin_application_settings_path
page.within('.as-visibility-access') do expect(Gitlab::CurrentSettings.project_export_enabled).to be_falsey
uncheck 'Project export enabled' expect(page).to have_content "Application settings saved successfully"
click_button 'Save changes'
end end
expect(Gitlab::CurrentSettings.project_export_enabled).to be_falsey it 'Change Keys settings' do
expect(page).to have_content "Application settings saved successfully" page.within('.as-visibility-access') do
end 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
it 'Change Account and Limit Settings' do forbidden = ApplicationSetting::FORBIDDEN_KEY_VALUE.to_s
visit admin_application_settings_path
page.within('.as-account-limit') do expect(page).to have_content 'Application settings saved successfully'
uncheck 'Gravatar enabled' expect(find_field('RSA SSH keys').value).to eq(forbidden)
click_button 'Save changes' 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 end
expect(Gitlab::CurrentSettings.gravatar_enabled).to be_falsey it 'Change Account and Limit Settings' do
expect(page).to have_content "Application settings saved successfully" page.within('.as-account-limit') do
end uncheck 'Gravatar enabled'
click_button 'Save changes'
end
it 'Change New users set to external', :js do expect(Gitlab::CurrentSettings.gravatar_enabled).to be_falsey
visit admin_application_settings_path expect(page).to have_content "Application settings saved successfully"
end
user_internal_regex = find('#application_setting_user_default_internal_regex', visible: :all) it 'Change New users set to external', :js do
user_internal_regex = find('#application_setting_user_default_internal_regex', visible: :all)
expect(user_internal_regex).to be_readonly 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' expect(user_internal_regex['placeholder']).to eq 'To define internal users, first enable new users set to external'
check 'application_setting_user_default_external' check 'application_setting_user_default_external'
expect(user_internal_regex).not_to be_readonly expect(user_internal_regex).not_to be_readonly
expect(user_internal_regex['placeholder']).to eq 'Regex pattern' expect(user_internal_regex['placeholder']).to eq 'Regex pattern'
end end
it 'Change Sign-in restrictions' do it 'Change Sign-in restrictions' do
visit admin_application_settings_path page.within('.as-signin') do
fill_in 'Home page URL', with: 'https://about.gitlab.com/'
click_button 'Save changes'
end
page.within('.as-signin') do expect(Gitlab::CurrentSettings.home_page_url).to eq "https://about.gitlab.com/"
fill_in 'Home page URL', with: 'https://about.gitlab.com/' expect(page).to have_content "Application settings saved successfully"
click_button 'Save changes'
end end
expect(Gitlab::CurrentSettings.home_page_url).to eq "https://about.gitlab.com/" it 'Terms of Service' do
expect(page).to have_content "Application settings saved successfully" # Already have the admin accept terms, so they don't need to accept in this spec.
end _existing_terms = create(:term)
accept_terms(admin)
it 'Terms of Service' do
visit admin_application_settings_path
# Already have the admin accept terms, so they don't need to accept in this spec. page.within('.as-terms') do
_existing_terms = create(:term) check 'Require all users to accept Terms of Service and Privacy Policy when they access GitLab.'
accept_terms(admin) fill_in 'Terms of Service Agreement', with: 'Be nice!'
click_button 'Save changes'
end
page.within('.as-terms') do expect(Gitlab::CurrentSettings.enforce_terms).to be(true)
check 'Require all users to accept Terms of Service and Privacy Policy when they access GitLab.' expect(Gitlab::CurrentSettings.terms).to eq 'Be nice!'
fill_in 'Terms of Service Agreement', with: 'Be nice!' expect(page).to have_content 'Application settings saved successfully'
click_button 'Save changes'
end end
expect(Gitlab::CurrentSettings.enforce_terms).to be(true) it 'Modify oauth providers' do
expect(Gitlab::CurrentSettings.terms).to eq 'Be nice!' expect(Gitlab::CurrentSettings.disabled_oauth_sign_in_sources).to be_empty
expect(page).to have_content 'Application settings saved successfully'
end
it 'Modify oauth providers' do page.within('.as-signin') do
visit admin_application_settings_path uncheck 'Google'
click_button 'Save changes'
end
expect(page).to have_content "Application settings saved successfully"
expect(Gitlab::CurrentSettings.disabled_oauth_sign_in_sources).to include('google_oauth2')
expect(Gitlab::CurrentSettings.disabled_oauth_sign_in_sources).to be_empty page.within('.as-signin') do
check "Google"
click_button 'Save changes'
end
page.within('.as-signin') do expect(page).to have_content "Application settings saved successfully"
uncheck 'Google' expect(Gitlab::CurrentSettings.disabled_oauth_sign_in_sources).not_to include('google_oauth2')
click_button 'Save changes'
end end
expect(page).to have_content "Application settings saved successfully" it 'Oauth providers do not raise validation errors when saving unrelated changes' do
expect(Gitlab::CurrentSettings.disabled_oauth_sign_in_sources).to include('google_oauth2') expect(Gitlab::CurrentSettings.disabled_oauth_sign_in_sources).to be_empty
page.within('.as-signin') do page.within('.as-signin') do
check "Google" uncheck 'Google'
click_button 'Save changes' click_button 'Save changes'
end end
expect(page).to have_content "Application settings saved successfully" expect(page).to have_content "Application settings saved successfully"
expect(Gitlab::CurrentSettings.disabled_oauth_sign_in_sources).not_to include('google_oauth2') expect(Gitlab::CurrentSettings.disabled_oauth_sign_in_sources).to include('google_oauth2')
end
it 'Oauth providers do not raise validation errors when saving unrelated changes' do # Remove google_oauth2 from the Omniauth strategies
visit admin_application_settings_path allow(Devise).to receive(:omniauth_providers).and_return([])
expect(Gitlab::CurrentSettings.disabled_oauth_sign_in_sources).to be_empty # Save an unrelated setting
page.within('.as-terms') do
click_button 'Save changes'
end
page.within('.as-signin') do expect(page).to have_content "Application settings saved successfully"
uncheck 'Google' expect(Gitlab::CurrentSettings.disabled_oauth_sign_in_sources).to include('google_oauth2')
click_button 'Save changes'
end end
expect(page).to have_content "Application settings saved successfully" it 'Configure web terminal' do
expect(Gitlab::CurrentSettings.disabled_oauth_sign_in_sources).to include('google_oauth2') page.within('.as-terminal') do
fill_in 'Max session time', with: 15
# Remove google_oauth2 from the Omniauth strategies click_button 'Save changes'
allow(Devise).to receive(:omniauth_providers).and_return([]) end
# Save an unrelated setting expect(page).to have_content "Application settings saved successfully"
page.within('.as-terms') do expect(Gitlab::CurrentSettings.terminal_max_session_time).to eq(15)
click_button 'Save changes'
end end
expect(page).to have_content "Application settings saved successfully"
expect(Gitlab::CurrentSettings.disabled_oauth_sign_in_sources).to include('google_oauth2')
end end
it 'Change Help page' do context 'Integrations page' do
visit preferences_admin_application_settings_path before do
visit integrations_admin_application_settings_path
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: 'http://example.com/help'
click_button 'Save changes'
end end
expect(Gitlab::CurrentSettings.help_page_text).to eq "Example text" it 'Enable hiding third party offers' do
expect(Gitlab::CurrentSettings.help_page_hide_commercial_content).to be_truthy page.within('.as-third-party-offers') do
expect(Gitlab::CurrentSettings.help_page_support_url).to eq "http://example.com/help" check 'Do not display offers from third parties within GitLab'
expect(page).to have_content "Application settings saved successfully" click_button 'Save changes'
end end
it 'Change Pages settings' do
visit preferences_admin_application_settings_path
page.within('.as-pages') do expect(page).to have_content "Application settings saved successfully"
fill_in 'Maximum size of pages (MB)', with: 15 expect(Gitlab::CurrentSettings.hide_third_party_offers).to be true
check 'Require users to prove ownership of custom domains'
click_button 'Save changes'
end end
expect(Gitlab::CurrentSettings.max_pages_size).to eq 15 it 'Change Slack Notifications Service template settings' do
expect(Gitlab::CurrentSettings.pages_domain_verification_enabled?).to be_truthy first(:link, 'Service Templates').click
expect(page).to have_content "Application settings saved successfully" click_link 'Slack notifications'
end fill_in 'Webhook', with: 'http://localhost'
fill_in 'Username', with: 'test_user'
fill_in 'service_push_channel', with: '#test_channel'
page.check('Notify only broken pipelines')
page.check('Notify only default branch')
it 'Change CI/CD settings' do check_all_events
visit ci_cd_admin_application_settings_path click_on 'Save'
page.within('.as-ci-cd') do expect(page).to have_content 'Application settings saved successfully'
check 'Default to Auto DevOps pipeline for all projects'
fill_in 'Auto devops domain', with: 'domain.com'
click_button 'Save changes'
end
expect(Gitlab::CurrentSettings.auto_devops_enabled?).to be true click_link 'Slack notifications'
expect(Gitlab::CurrentSettings.auto_devops_domain).to eq('domain.com')
expect(page).to have_content "Application settings saved successfully"
end
it 'Change Influx settings' do page.all('input[type=checkbox]').each do |checkbox|
visit metrics_and_profiling_admin_application_settings_path expect(checkbox).to be_checked
end
page.within('.as-influx') do expect(find_field('Webhook').value).to eq 'http://localhost'
check 'Enable InfluxDB Metrics' expect(find_field('Username').value).to eq 'test_user'
click_button 'Save changes' expect(find('#service_push_channel').value).to eq '#test_channel'
end end
expect(Gitlab::CurrentSettings.metrics_enabled?).to be true
expect(page).to have_content "Application settings saved successfully"
end end
it 'Change Prometheus settings' do context 'CI/CD page' do
visit metrics_and_profiling_admin_application_settings_path it 'Change CI/CD settings' do
visit ci_cd_admin_application_settings_path
page.within('.as-prometheus') do page.within('.as-ci-cd') do
check 'Enable Prometheus Metrics' check 'Default to Auto DevOps pipeline for all projects'
click_button 'Save changes' fill_in 'Auto devops domain', with: 'domain.com'
end click_button 'Save changes'
end
expect(Gitlab::CurrentSettings.prometheus_metrics_enabled?).to be true expect(Gitlab::CurrentSettings.auto_devops_enabled?).to be true
expect(page).to have_content "Application settings saved successfully" expect(Gitlab::CurrentSettings.auto_devops_domain).to eq('domain.com')
expect(page).to have_content "Application settings saved successfully"
end
end end
it 'Change Performance bar settings' do context 'Reporting page' do
visit metrics_and_profiling_admin_application_settings_path it 'Change Spam settings' do
visit reporting_admin_application_settings_path
group = create(:group) page.within('.as-spam') do
check 'Enable reCAPTCHA'
fill_in 'reCAPTCHA Site Key', with: 'key'
fill_in 'reCAPTCHA Private Key', with: 'key'
fill_in 'IPs per user', with: 15
click_button 'Save changes'
end
page.within('.as-performance-bar') do expect(page).to have_content "Application settings saved successfully"
check 'Enable the Performance Bar' expect(Gitlab::CurrentSettings.recaptcha_enabled).to be true
fill_in 'Allowed group', with: group.path expect(Gitlab::CurrentSettings.unique_ips_limit_per_user).to eq(15)
click_on 'Save changes'
end end
end
expect(page).to have_content "Application settings saved successfully" context 'Metrics and profiling page' do
expect(find_field('Enable the Performance Bar')).to be_checked before do
expect(find_field('Allowed group').value).to eq group.path visit metrics_and_profiling_admin_application_settings_path
page.within('.as-performance-bar') do
uncheck 'Enable the Performance Bar'
click_on 'Save changes'
end end
expect(page).to have_content 'Application settings saved successfully' it 'Change Influx settings' do
expect(find_field('Enable the Performance Bar')).not_to be_checked page.within('.as-influx') do
expect(find_field('Allowed group').value).to be_nil check 'Enable InfluxDB Metrics'
end click_button 'Save changes'
end
it 'Change Background jobs settings' do
visit preferences_admin_application_settings_path
page.within('.as-background') do expect(Gitlab::CurrentSettings.metrics_enabled?).to be true
fill_in 'Throttling Factor', with: 1 expect(page).to have_content "Application settings saved successfully"
click_button 'Save changes'
end end
expect(Gitlab::CurrentSettings.sidekiq_throttling_factor).to eq(1) it 'Change Prometheus settings' do
expect(page).to have_content "Application settings saved successfully" page.within('.as-prometheus') do
end check 'Enable Prometheus Metrics'
click_button 'Save changes'
it 'Change Spam settings' do end
visit reporting_admin_application_settings_path
page.within('.as-spam') do expect(Gitlab::CurrentSettings.prometheus_metrics_enabled?).to be true
check 'Enable reCAPTCHA' expect(page).to have_content "Application settings saved successfully"
fill_in 'reCAPTCHA Site Key', with: 'key'
fill_in 'reCAPTCHA Private Key', with: 'key'
fill_in 'IPs per user', with: 15
click_button 'Save changes'
end end
expect(page).to have_content "Application settings saved successfully" it 'Change Performance bar settings' do
expect(Gitlab::CurrentSettings.recaptcha_enabled).to be true group = create(:group)
expect(Gitlab::CurrentSettings.unique_ips_limit_per_user).to eq(15)
end
it 'Configure web terminal' do
visit admin_application_settings_path
page.within('.as-terminal') do page.within('.as-performance-bar') do
fill_in 'Max session time', with: 15 check 'Enable the Performance Bar'
click_button 'Save changes' fill_in 'Allowed group', with: group.path
end click_on 'Save changes'
end
expect(page).to have_content "Application settings saved successfully" expect(page).to have_content "Application settings saved successfully"
expect(Gitlab::CurrentSettings.terminal_max_session_time).to eq(15) expect(find_field('Enable the Performance Bar')).to be_checked
end expect(find_field('Allowed group').value).to eq group.path
it 'Enable outbound requests' do page.within('.as-performance-bar') do
visit network_admin_application_settings_path uncheck 'Enable the Performance Bar'
click_on 'Save changes'
end
page.within('.as-outbound') do expect(page).to have_content 'Application settings saved successfully'
check 'Allow requests to the local network from hooks and services' expect(find_field('Enable the Performance Bar')).not_to be_checked
click_button 'Save changes' expect(find_field('Allowed group').value).to be_nil
end end
expect(page).to have_content "Application settings saved successfully" it 'loads usage ping payload on click', :js do
expect(Gitlab::CurrentSettings.allow_local_requests_from_hooks_and_services).to be true expect(page).to have_button 'Preview payload'
end
it 'Enable hiding third party offers' do find('.js-usage-ping-payload-trigger').click
visit integrations_admin_application_settings_path
page.within('.as-third-party-offers') do expect(page).to have_selector '.js-usage-ping-payload'
check 'Do not display offers from third parties within GitLab' expect(page).to have_button 'Hide payload'
click_button 'Save changes'
end end
expect(page).to have_content "Application settings saved successfully"
expect(Gitlab::CurrentSettings.hide_third_party_offers).to be true
end end
it 'Change Slack Notifications Service template settings' do context 'Network page' do
visit integrations_admin_application_settings_path it 'Enable outbound requests' do
visit network_admin_application_settings_path
first(:link, 'Service Templates').click
click_link 'Slack notifications'
fill_in 'Webhook', with: 'http://localhost'
fill_in 'Username', with: 'test_user'
fill_in 'service_push_channel', with: '#test_channel'
page.check('Notify only broken pipelines')
page.check('Notify only default branch')
check_all_events
click_on 'Save'
expect(page).to have_content 'Application settings saved successfully'
click_link 'Slack notifications' page.within('.as-outbound') do
check 'Allow requests to the local network from hooks and services'
click_button 'Save changes'
end
page.all('input[type=checkbox]').each do |checkbox| expect(page).to have_content "Application settings saved successfully"
expect(checkbox).to be_checked expect(Gitlab::CurrentSettings.allow_local_requests_from_hooks_and_services).to be true
end end
expect(find_field('Webhook').value).to eq 'http://localhost'
expect(find_field('Username').value).to eq 'test_user'
expect(find('#service_push_channel').value).to eq '#test_channel'
end end
it 'Change Keys settings' do context 'Preferences page' do
visit admin_application_settings_path before do
visit preferences_admin_application_settings_path
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 end
forbidden = ApplicationSetting::FORBIDDEN_KEY_VALUE.to_s it 'Change Help page' do
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: 'http://example.com/help'
click_button 'Save changes'
end
expect(page).to have_content 'Application settings saved successfully' expect(Gitlab::CurrentSettings.help_page_text).to eq "Example text"
expect(find_field('RSA SSH keys').value).to eq(forbidden) expect(Gitlab::CurrentSettings.help_page_hide_commercial_content).to be_truthy
expect(find_field('DSA SSH keys').value).to eq('0') expect(Gitlab::CurrentSettings.help_page_support_url).to eq "http://example.com/help"
expect(find_field('ECDSA SSH keys').value).to eq('384') expect(page).to have_content "Application settings saved successfully"
expect(find_field('ED25519 SSH keys').value).to eq(forbidden) end
end
it 'loads usage ping payload on click', :js do it 'Change Pages settings' do
visit metrics_and_profiling_admin_application_settings_path 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
expect(page).to have_button 'Preview payload' expect(Gitlab::CurrentSettings.max_pages_size).to eq 15
expect(Gitlab::CurrentSettings.pages_domain_verification_enabled?).to be_truthy
expect(page).to have_content "Application settings saved successfully"
end
find('.js-usage-ping-payload-trigger').click it 'Change Background jobs settings' do
page.within('.as-background') do
fill_in 'Throttling Factor', with: 1
click_button 'Save changes'
end
expect(page).to have_selector '.js-usage-ping-payload' expect(Gitlab::CurrentSettings.sidekiq_throttling_factor).to eq(1)
expect(page).to have_button 'Hide payload' expect(page).to have_content "Application settings saved successfully"
end
end end
def check_all_events def check_all_events
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment