diff options
Diffstat (limited to 'spec/services/ci/job_token_scope')
-rw-r--r-- | spec/services/ci/job_token_scope/add_project_service_spec.rb | 20 | ||||
-rw-r--r-- | spec/services/ci/job_token_scope/remove_project_service_spec.rb | 20 |
2 files changed, 32 insertions, 8 deletions
diff --git a/spec/services/ci/job_token_scope/add_project_service_spec.rb b/spec/services/ci/job_token_scope/add_project_service_spec.rb index ba889465fac..bb6df4268dd 100644 --- a/spec/services/ci/job_token_scope/add_project_service_spec.rb +++ b/spec/services/ci/job_token_scope/add_project_service_spec.rb @@ -8,6 +8,14 @@ RSpec.describe Ci::JobTokenScope::AddProjectService do let_it_be(:target_project) { create(:project) } let_it_be(:current_user) { create(:user) } + shared_examples 'adds project' do |context| + it 'adds the project to the scope' do + expect do + expect(result).to be_success + end.to change { Ci::JobToken::ProjectScopeLink.count }.by(1) + end + end + describe '#execute' do subject(:result) { service.execute(target_project) } @@ -18,10 +26,14 @@ RSpec.describe Ci::JobTokenScope::AddProjectService do target_project.add_developer(current_user) end - it 'adds the project to the scope' do - expect do - expect(result).to be_success - end.to change { Ci::JobToken::ProjectScopeLink.count }.by(1) + it_behaves_like 'adds project' + + context 'when token scope is disabled' do + before do + project.ci_cd_settings.update!(job_token_scope_enabled: false) + end + + it_behaves_like 'adds project' end end diff --git a/spec/services/ci/job_token_scope/remove_project_service_spec.rb b/spec/services/ci/job_token_scope/remove_project_service_spec.rb index 238fc879f54..155e60ac48e 100644 --- a/spec/services/ci/job_token_scope/remove_project_service_spec.rb +++ b/spec/services/ci/job_token_scope/remove_project_service_spec.rb @@ -14,6 +14,14 @@ RSpec.describe Ci::JobTokenScope::RemoveProjectService do target_project: target_project) end + shared_examples 'removes project' do |context| + it 'removes the project from the scope' do + expect do + expect(result).to be_success + end.to change { Ci::JobToken::ProjectScopeLink.count }.by(-1) + end + end + describe '#execute' do subject(:result) { service.execute(target_project) } @@ -24,10 +32,14 @@ RSpec.describe Ci::JobTokenScope::RemoveProjectService do target_project.add_developer(current_user) end - it 'removes the project from the scope' do - expect do - expect(result).to be_success - end.to change { Ci::JobToken::ProjectScopeLink.count }.by(-1) + it_behaves_like 'removes project' + + context 'when token scope is disabled' do + before do + project.ci_cd_settings.update!(job_token_scope_enabled: false) + end + + it_behaves_like 'removes project' end end |