diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2020-07-15 15:09:26 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2020-07-15 15:09:26 +0300 |
commit | 9215d9f7619929f9da16744fa37636635b66949b (patch) | |
tree | 754fa5c3a99700176b117d96b30268cbd3c07581 /spec/services/deploy_keys | |
parent | a898b6057ecf9ab635c45217568d44eab5c32ec0 (diff) |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/services/deploy_keys')
-rw-r--r-- | spec/services/deploy_keys/collect_keys_service_spec.rb | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/spec/services/deploy_keys/collect_keys_service_spec.rb b/spec/services/deploy_keys/collect_keys_service_spec.rb new file mode 100644 index 00000000000..3442e5e456a --- /dev/null +++ b/spec/services/deploy_keys/collect_keys_service_spec.rb @@ -0,0 +1,58 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe DeployKeys::CollectKeysService do + let_it_be(:user) { create(:user) } + let_it_be(:project) { create(:project, :private) } + + subject { DeployKeys::CollectKeysService.new(project, user) } + + before do + project&.add_developer(user) + end + + context 'when no project is passed in' do + let(:project) { nil } + + it 'returns an empty Array' do + expect(subject.execute).to be_empty + end + end + + context 'when no user is passed in' do + let(:user) { nil } + + it 'returns an empty Array' do + expect(subject.execute).to be_empty + end + end + + context 'when a project is passed in' do + let_it_be(:deploy_keys_project) { create(:deploy_keys_project, :write_access, project: project) } + let_it_be(:deploy_key) { deploy_keys_project.deploy_key } + + it 'only returns deploy keys with write access' do + create(:deploy_keys_project, project: project) + + expect(subject.execute).to contain_exactly(deploy_key) + end + + it 'returns deploy keys only for this project' do + other_project = create(:project) + create(:deploy_keys_project, :write_access, project: other_project) + + expect(subject.execute).to contain_exactly(deploy_key) + end + end + + context 'when the user cannot read the project' do + before do + project.members.delete_all + end + + it 'returns an empty Array' do + expect(subject.execute).to be_empty + end + end +end |