diff options
Diffstat (limited to 'spec/features/projects/pipeline_schedules_spec.rb')
-rw-r--r-- | spec/features/projects/pipeline_schedules_spec.rb | 55 |
1 files changed, 33 insertions, 22 deletions
diff --git a/spec/features/projects/pipeline_schedules_spec.rb b/spec/features/projects/pipeline_schedules_spec.rb index 599f5a1ffb7..5bcd0d28fd9 100644 --- a/spec/features/projects/pipeline_schedules_spec.rb +++ b/spec/features/projects/pipeline_schedules_spec.rb @@ -2,7 +2,7 @@ require 'spec_helper' -RSpec.describe 'Pipeline Schedules', :js, feature_category: :groups_and_projects do +RSpec.describe 'Pipeline Schedules', :js, feature_category: :continuous_integration do include Spec::Support::Helpers::ModalHelpers let!(:project) { create(:project, :repository) } @@ -106,7 +106,7 @@ RSpec.describe 'Pipeline Schedules', :js, feature_category: :groups_and_projects wait_for_requests end - describe 'The view' do + describe 'the view' do it 'displays the required information description' do page.within('[data-testid="pipeline-schedule-table-row"]') do expect(page).to have_content('pipeline schedule') @@ -293,36 +293,47 @@ RSpec.describe 'Pipeline Schedules', :js, feature_category: :groups_and_projects end end - context 'logged in as non-member' do - before do - gitlab_sign_in(user) - end - + shared_examples 'when not logged in' do describe 'GET /projects/pipeline_schedules' do - before do - visit_pipelines_schedules - end - - describe 'The view' do + describe 'the view' do it 'does not show create schedule button' do + visit_pipelines_schedules + expect(page).not_to have_link('New schedule') end + + context 'when project is public' do + let_it_be(:project) { create(:project, :repository, :public, public_builds: true) } + + it 'shows Pipelines Schedules page' do + visit_pipelines_schedules + + expect(page).to have_link('New schedule') + end + + context 'when public pipelines are disabled' do + before do + project.update!(public_builds: false) + visit_pipelines_schedules + end + + it 'shows Not Found page' do + expect(page).to have_content('Page Not Found') + end + end + end end end end - context 'not logged in' do - describe 'GET /projects/pipeline_schedules' do - before do - visit_pipelines_schedules - end + it_behaves_like 'when not logged in' - describe 'The view' do - it 'does not show create schedule button' do - expect(page).not_to have_link('New schedule') - end - end + context 'logged in as non-member' do + before do + gitlab_sign_in(user) end + + it_behaves_like 'when not logged in' end def visit_new_pipeline_schedule |