summaryrefslogtreecommitdiff
path: root/spec
diff options
context:
space:
mode:
authorDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2017-03-09 13:54:43 +0000
committerDmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>2017-03-09 13:54:43 +0000
commitca66799267616810f4c1bae75ab0006201c094a4 (patch)
tree51a7452d1805842859efc35654ee67366d62b43b /spec
parent03476ac0bc2a06f19057475d8982055c12a6c0a9 (diff)
parent5b52adcedb78287c4599ead8ffc1d00f84dc4e55 (diff)
downloadgitlab-ce-ca66799267616810f4c1bae75ab0006201c094a4.tar.gz
Merge branch 'dz-nested-groups-members' into 'master'
Show members of parent groups on project members page Closes #28786 and #27962 See merge request !9764
Diffstat (limited to 'spec')
-rw-r--r--spec/finders/members_finder_spec.rb22
1 files changed, 22 insertions, 0 deletions
diff --git a/spec/finders/members_finder_spec.rb b/spec/finders/members_finder_spec.rb
new file mode 100644
index 00000000000..cf691cf684b
--- /dev/null
+++ b/spec/finders/members_finder_spec.rb
@@ -0,0 +1,22 @@
+require 'spec_helper'
+
+describe MembersFinder, '#execute' do
+ let(:group) { create(:group) }
+ let(:nested_group) { create(:group, :access_requestable, parent: group) }
+ let(:project) { create(:project, namespace: nested_group) }
+ let(:user1) { create(:user) }
+ let(:user2) { create(:user) }
+ let(:user3) { create(:user) }
+ let(:user4) { create(:user) }
+
+ it 'returns members for project and parent groups' do
+ nested_group.request_access(user1)
+ member1 = group.add_master(user2)
+ member2 = nested_group.add_master(user3)
+ member3 = project.add_master(user4)
+
+ result = described_class.new(project, user2).execute
+
+ expect(result.to_a).to eq([member3, member2, member1])
+ end
+end