2019-10-12 21:52:04 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2019-07-07 11:18:12 +05:30
|
|
|
RSpec.shared_context 'MergeRequestsFinder multiple projects with merge requests context' do
|
|
|
|
include ProjectForksHelper
|
|
|
|
|
|
|
|
# We need to explicitly permit Gitaly N+1s because of the specs that use
|
|
|
|
# :request_store. Gitaly N+1 detection is only enabled when :request_store is,
|
|
|
|
# but we don't care about potential N+1s when we're just creating several
|
|
|
|
# projects in the setup phase.
|
|
|
|
def allow_gitaly_n_plus_1
|
|
|
|
Gitlab::GitalyClient.allow_n_plus_1_calls do
|
|
|
|
yield
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2020-04-22 19:07:51 +05:30
|
|
|
let_it_be(:user) { create(:user) }
|
|
|
|
let_it_be(:user2) { create(:user) }
|
|
|
|
let_it_be(:group) { create(:group) }
|
|
|
|
let_it_be(:subgroup) { create(:group, parent: group) }
|
|
|
|
let_it_be(:project1, reload: true) do
|
2019-07-07 11:18:12 +05:30
|
|
|
allow_gitaly_n_plus_1 { create(:project, :public, group: group) }
|
|
|
|
end
|
2020-04-22 19:07:51 +05:30
|
|
|
# We cannot use `let_it_be` here otherwise we get:
|
2019-07-07 11:18:12 +05:30
|
|
|
# Failure/Error: allow(RepositoryForkWorker).to receive(:perform_async).and_return(true)
|
|
|
|
# The use of doubles or partial doubles from rspec-mocks outside of the per-test lifecycle is not supported.
|
|
|
|
let(:project2) do
|
|
|
|
allow_gitaly_n_plus_1 do
|
|
|
|
fork_project(project1, user)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
let(:project3) do
|
|
|
|
allow_gitaly_n_plus_1 do
|
|
|
|
fork_project(project1, user).tap do |project|
|
|
|
|
project.update!(archived: true)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2020-04-22 19:07:51 +05:30
|
|
|
let_it_be(:project4, reload: true) do
|
2019-07-07 11:18:12 +05:30
|
|
|
allow_gitaly_n_plus_1 { create(:project, :repository, group: subgroup) }
|
|
|
|
end
|
2020-04-22 19:07:51 +05:30
|
|
|
let_it_be(:project5, reload: true) do
|
2019-07-07 11:18:12 +05:30
|
|
|
allow_gitaly_n_plus_1 { create(:project, group: subgroup) }
|
|
|
|
end
|
2020-04-22 19:07:51 +05:30
|
|
|
let_it_be(:project6, reload: true) do
|
2019-07-07 11:18:12 +05:30
|
|
|
allow_gitaly_n_plus_1 { create(:project, group: subgroup) }
|
|
|
|
end
|
|
|
|
|
2019-07-31 22:56:46 +05:30
|
|
|
let!(:merge_request1) { create(:merge_request, assignees: [user], author: user, source_project: project2, target_project: project1, target_branch: 'merged-target') }
|
|
|
|
let!(:merge_request2) { create(:merge_request, :conflict, assignees: [user], author: user, source_project: project2, target_project: project1, state: 'closed') }
|
|
|
|
let!(:merge_request3) { create(:merge_request, :simple, author: user, assignees: [user2], source_project: project2, target_project: project2, state: 'locked', title: 'thing WIP thing') }
|
2019-07-07 11:18:12 +05:30
|
|
|
let!(:merge_request4) { create(:merge_request, :simple, author: user, source_project: project3, target_project: project3, title: 'WIP thing') }
|
|
|
|
let!(:merge_request5) { create(:merge_request, :simple, author: user, source_project: project4, target_project: project4, title: '[WIP]') }
|
|
|
|
|
|
|
|
before do
|
|
|
|
project1.add_maintainer(user)
|
|
|
|
project2.add_developer(user)
|
|
|
|
project3.add_developer(user)
|
|
|
|
project4.add_developer(user)
|
|
|
|
project5.add_developer(user)
|
|
|
|
project6.add_developer(user)
|
|
|
|
|
|
|
|
project2.add_developer(user2)
|
|
|
|
end
|
|
|
|
end
|