diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2020-08-20 21:42:06 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2020-08-20 21:42:06 +0300 |
commit | 6e4e1050d9dba2b7b2523fdd1768823ab85feef4 (patch) | |
tree | 78be5963ec075d80116a932011d695dd33910b4e /spec/finders/members_finder_spec.rb | |
parent | 1ce776de4ae122aba3f349c02c17cebeaa8ecf07 (diff) |
Add latest changes from gitlab-org/gitlab@13-3-stable-ee
Diffstat (limited to 'spec/finders/members_finder_spec.rb')
-rw-r--r-- | spec/finders/members_finder_spec.rb | 25 |
1 files changed, 24 insertions, 1 deletions
diff --git a/spec/finders/members_finder_spec.rb b/spec/finders/members_finder_spec.rb index b14ad84a96e..3ef8d6a01aa 100644 --- a/spec/finders/members_finder_spec.rb +++ b/spec/finders/members_finder_spec.rb @@ -10,16 +10,39 @@ RSpec.describe MembersFinder, '#execute' do let_it_be(:user2) { create(:user) } let_it_be(:user3) { create(:user) } let_it_be(:user4) { create(:user) } + let_it_be(:blocked_user) { create(:user, :blocked) } it 'returns members for project and parent groups' do nested_group.request_access(user1) member1 = group.add_maintainer(user2) member2 = nested_group.add_maintainer(user3) member3 = project.add_maintainer(user4) + blocked_member = project.add_maintainer(blocked_user) result = described_class.new(project, user2).execute - expect(result).to contain_exactly(member1, member2, member3) + expect(result).to contain_exactly(member1, member2, member3, blocked_member) + end + + it 'returns owners and maintainers' do + member1 = group.add_owner(user1) + group.add_developer(user2) + member3 = project.add_maintainer(user3) + project.add_developer(user4) + + result = described_class.new(project, user2, params: { owners_and_maintainers: true }).execute + + expect(result).to contain_exactly(member1, member3) + end + + it 'returns active users and excludes invited users' do + member1 = project.add_maintainer(user2) + create(:project_member, :invited, project: project, invite_email: create(:user).email) + project.add_maintainer(blocked_user) + + result = described_class.new(project, user2, params: { active_without_invites_and_requests: true }).execute + + expect(result).to contain_exactly(member1) end it 'includes only non-invite members if user do not have amdin permissions on project' do |