diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2021-07-29 00:08:53 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2021-07-29 00:08:53 +0300 |
commit | 112fe349cb75b79a0075f5d3f89cf847b7beaf2d (patch) | |
tree | 9b1e1e9c61ab05e6725f7f961d02ddb57bf2d616 /spec/finders | |
parent | a66948df0c3fda7764965f8cf4c9c99226c0d44d (diff) |
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'spec/finders')
-rw-r--r-- | spec/finders/lfs_pointers_finder_spec.rb | 44 | ||||
-rw-r--r-- | spec/finders/projects/members/effective_access_level_per_user_finder_spec.rb | 38 |
2 files changed, 82 insertions, 0 deletions
diff --git a/spec/finders/lfs_pointers_finder_spec.rb b/spec/finders/lfs_pointers_finder_spec.rb new file mode 100644 index 00000000000..2f45f383f2f --- /dev/null +++ b/spec/finders/lfs_pointers_finder_spec.rb @@ -0,0 +1,44 @@ +# frozen_string_literal: true + +require 'spec_helper' + +RSpec.describe LfsPointersFinder do + subject(:finder) { described_class.new(repository, path) } + + let_it_be(:project) { create(:project, :repository) } + let_it_be(:repository) { project.repository } + + let(:path) { nil } + + describe '#execute' do + subject { finder.execute } + + let(:expected_blob_id) { '0c304a93cb8430108629bbbcaa27db3343299bc0' } + + context 'when path has no LFS files' do + it { is_expected.to eq([]) } + end + + context 'when path points to LFS file' do + let(:path) { 'files/lfs/lfs_object.iso' } + + it 'returns LFS blob ids' do + is_expected.to eq([expected_blob_id]) + end + end + + context 'when path points to directory with LFS files' do + let(:path) { 'files/lfs/' } + + it 'returns LFS blob ids' do + is_expected.to eq([expected_blob_id]) + end + end + + context 'when repository is empty' do + let(:project) { create(:project, :empty_repo) } + + it { is_expected.to eq([]) } + end + end +end diff --git a/spec/finders/projects/members/effective_access_level_per_user_finder_spec.rb b/spec/finders/projects/members/effective_access_level_per_user_finder_spec.rb new file mode 100644 index 00000000000..3872938d20e --- /dev/null +++ b/spec/finders/projects/members/effective_access_level_per_user_finder_spec.rb @@ -0,0 +1,38 @@ +# frozen_string_literal: true +require 'spec_helper' + +RSpec.describe Projects::Members::EffectiveAccessLevelPerUserFinder, '#execute' do + let_it_be(:group) { create(:group) } + let_it_be(:project) { create(:project, group: group) } + let_it_be(:user) { create(:user) } + + # The result set is being converted to json just for the ease of testing. + subject { described_class.new(project, user).execute.as_json } + + context 'a combination of all possible avenues of membership' do + let_it_be(:another_user) { create(:user) } + let_it_be(:shared_with_group) { create(:group) } + + before do + create(:project_group_link, :maintainer, project: project, group: shared_with_group) + create(:group_group_link, :reporter, shared_group: project.group, shared_with_group: shared_with_group) + + shared_with_group.add_maintainer(user) + shared_with_group.add_maintainer(another_user) + group.add_guest(user) + group.add_guest(another_user) + project.add_developer(user) + project.add_developer(another_user) + end + + it 'includes the highest access level from all avenues of memberships for the specific user alone' do + expect(subject).to eq( + [{ + 'user_id' => user.id, + 'access_level' => Gitlab::Access::MAINTAINER, # From project_group_link + 'id' => nil + }] + ) + end + end +end |