[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
2 changed files with 43 additions and 20 deletions
|
@ -1,26 +1,7 @@
|
||||||
require 'spec_helper'
|
require 'spec_helper'
|
||||||
|
|
||||||
describe GroupProjectsFinder do
|
describe GroupProjectsFinder do
|
||||||
let(:group) { create(:group) }
|
include_context 'GroupProjectsFinder context'
|
||||||
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
|
|
||||||
|
|
||||||
subject { finder.execute }
|
subject { finder.execute }
|
||||||
|
|
||||||
|
@ -144,6 +125,24 @@ describe GroupProjectsFinder do
|
||||||
end
|
end
|
||||||
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
|
describe "no user" do
|
||||||
context "only shared" do
|
context "only shared" do
|
||||||
let(:options) { { only_shared: true } }
|
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 a new issue