[CE] Reduce differences with EE in group_projects_finder_spec.rb
Signed-off-by: Rémy Coutable <remy@rymai.me>
This commit is contained in:
parent
284d3e563e
commit
30a4e5532d
|
@ -1,26 +1,7 @@
|
|||
require 'spec_helper'
|
||||
|
||||
describe GroupProjectsFinder do
|
||||
let(:group) { create(:group) }
|
||||
let(:subgroup) { create(:group, parent: group) }
|
||||
let(:current_user) { create(:user) }
|
||||
let(:options) { {} }
|
||||
|
||||
let(:finder) { described_class.new(group: group, current_user: current_user, options: options) }
|
||||
|
||||
let!(:public_project) { create(:project, :public, group: group, path: '1') }
|
||||
let!(:private_project) { create(:project, :private, group: group, path: '2') }
|
||||
let!(:shared_project_1) { create(:project, :public, path: '3') }
|
||||
let!(:shared_project_2) { create(:project, :private, path: '4') }
|
||||
let!(:shared_project_3) { create(:project, :internal, path: '5') }
|
||||
let!(:subgroup_project) { create(:project, :public, path: '6', group: subgroup) }
|
||||
let!(:subgroup_private_project) { create(:project, :private, path: '7', group: subgroup) }
|
||||
|
||||
before do
|
||||
shared_project_1.project_group_links.create(group_access: Gitlab::Access::MAINTAINER, group: group)
|
||||
shared_project_2.project_group_links.create(group_access: Gitlab::Access::MAINTAINER, group: group)
|
||||
shared_project_3.project_group_links.create(group_access: Gitlab::Access::MAINTAINER, group: group)
|
||||
end
|
||||
include_context 'GroupProjectsFinder context'
|
||||
|
||||
subject { finder.execute }
|
||||
|
||||
|
@ -144,6 +125,24 @@ describe GroupProjectsFinder do
|
|||
end
|
||||
end
|
||||
|
||||
describe 'with an admin current user' do
|
||||
let(:current_user) { create(:admin) }
|
||||
|
||||
context "only shared" do
|
||||
let(:options) { { only_shared: true } }
|
||||
it { is_expected.to eq([shared_project_3, shared_project_2, shared_project_1]) }
|
||||
end
|
||||
|
||||
context "only owned" do
|
||||
let(:options) { { only_owned: true } }
|
||||
it { is_expected.to eq([private_project, public_project]) }
|
||||
end
|
||||
|
||||
context "all" do
|
||||
it { is_expected.to eq([shared_project_3, shared_project_2, shared_project_1, private_project, public_project]) }
|
||||
end
|
||||
end
|
||||
|
||||
describe "no user" do
|
||||
context "only shared" do
|
||||
let(:options) { { only_shared: true } }
|
||||
|
|
|
@ -0,0 +1,24 @@
|
|||
require 'spec_helper'
|
||||
|
||||
RSpec.shared_context 'GroupProjectsFinder context' do
|
||||
let(:group) { create(:group) }
|
||||
let(:subgroup) { create(:group, parent: group) }
|
||||
let(:current_user) { create(:user) }
|
||||
let(:options) { {} }
|
||||
|
||||
let(:finder) { described_class.new(group: group, current_user: current_user, options: options) }
|
||||
|
||||
let!(:public_project) { create(:project, :public, group: group, path: '1') }
|
||||
let!(:private_project) { create(:project, :private, group: group, path: '2') }
|
||||
let!(:shared_project_1) { create(:project, :public, path: '3') }
|
||||
let!(:shared_project_2) { create(:project, :private, path: '4') }
|
||||
let!(:shared_project_3) { create(:project, :internal, path: '5') }
|
||||
let!(:subgroup_project) { create(:project, :public, path: '6', group: subgroup) }
|
||||
let!(:subgroup_private_project) { create(:project, :private, path: '7', group: subgroup) }
|
||||
|
||||
before do
|
||||
shared_project_1.project_group_links.create(group_access: Gitlab::Access::MAINTAINER, group: group)
|
||||
shared_project_2.project_group_links.create(group_access: Gitlab::Access::MAINTAINER, group: group)
|
||||
shared_project_3.project_group_links.create(group_access: Gitlab::Access::MAINTAINER, group: group)
|
||||
end
|
||||
end
|
Loading…
Reference in New Issue