debian-mirror-gitlab/spec/features/groups/settings/ci_cd_spec.rb

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

120 lines
3.3 KiB
Ruby
Raw Normal View History

2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
require 'spec_helper'
2020-06-23 00:09:42 +05:30
RSpec.describe 'Group CI/CD settings' do
2018-12-05 23:21:45 +05:30
include WaitForRequests
2022-06-21 17:19:12 +05:30
let_it_be(:user) { create(:user) }
let_it_be(:group, reload: true) { create(:group) }
2018-12-05 23:21:45 +05:30
2022-06-21 17:19:12 +05:30
before_all do
2018-12-05 23:21:45 +05:30
group.add_owner(user)
2022-06-21 17:19:12 +05:30
end
before do
2018-12-05 23:21:45 +05:30
sign_in(user)
end
2022-06-21 17:19:12 +05:30
describe 'Runners section' do
let(:shared_runners_toggle) { page.find('[data-testid="enable-runners-toggle"]') }
2022-05-07 20:08:51 +05:30
2022-06-21 17:19:12 +05:30
context 'with runner_list_group_view_vue_ui enabled' do
before do
visit group_settings_ci_cd_path(group)
end
it 'displays the new group runners view banner' do
expect(page).to have_content(s_('Runners|New group runners view'))
expect(page).to have_link(href: group_runners_path(group))
end
it 'has "Enable shared runners for this group" toggle', :js do
expect(shared_runners_toggle).to have_content(_('Enable shared runners for this group'))
end
2022-05-07 20:08:51 +05:30
end
2022-06-21 17:19:12 +05:30
context 'with runner_list_group_view_vue_ui disabled' do
before do
stub_feature_flags(runner_list_group_view_vue_ui: false)
visit group_settings_ci_cd_path(group)
end
2022-05-07 20:08:51 +05:30
2022-06-21 17:19:12 +05:30
it 'does not display the new group runners view banner' do
expect(page).not_to have_content(s_('Runners|New group runners view'))
expect(page).not_to have_link(href: group_runners_path(group))
end
2022-05-07 20:08:51 +05:30
2022-06-21 17:19:12 +05:30
it 'has "Enable shared runners for this group" toggle', :js do
expect(shared_runners_toggle).to have_content(_('Enable shared runners for this group'))
end
2022-05-07 20:08:51 +05:30
2022-06-21 17:19:12 +05:30
context 'with runners registration token' do
let!(:token) { group.runners_token }
2018-12-05 23:21:45 +05:30
2022-06-21 17:19:12 +05:30
before do
visit group_settings_ci_cd_path(group)
end
2018-12-05 23:21:45 +05:30
2022-06-21 17:19:12 +05:30
it 'displays the registration token' do
expect(page.find('#registration_token')).to have_content(token)
end
2018-12-05 23:21:45 +05:30
2022-06-21 17:19:12 +05:30
describe 'reload registration token' do
let(:page_token) { find('#registration_token').text }
2018-12-05 23:21:45 +05:30
2022-06-21 17:19:12 +05:30
before do
click_button 'Reset registration token'
end
2018-12-05 23:21:45 +05:30
2022-06-21 17:19:12 +05:30
it 'changes the registration token' do
expect(page_token).not_to eq token
end
end
2018-12-05 23:21:45 +05:30
end
end
end
2019-07-07 11:18:12 +05:30
describe 'Auto DevOps form' do
before do
stub_application_setting(auto_devops_enabled: true)
end
context 'as owner first visiting group settings' do
it 'sees instance enabled badge' do
visit group_settings_ci_cd_path(group)
page.within '#auto-devops-settings' do
expect(page).to have_content('instance enabled')
end
end
end
context 'when Auto DevOps group has been enabled' do
it 'sees group enabled badge' do
group.update!(auto_devops_enabled: true)
visit group_settings_ci_cd_path(group)
page.within '#auto-devops-settings' do
expect(page).to have_content('group enabled')
end
end
end
context 'when Auto DevOps group has been disabled' do
it 'does not see a badge' do
group.update!(auto_devops_enabled: false)
visit group_settings_ci_cd_path(group)
page.within '#auto-devops-settings' do
expect(page).not_to have_content('instance enabled')
expect(page).not_to have_content('group enabled')
end
end
end
end
2018-12-05 23:21:45 +05:30
end