Commit eac20b74 authored by Sean McGivern's avatar Sean McGivern

Merge branch 'backport-ee-merge-spec-changes' into 'master'

Backport EE merge spec changes

See merge request gitlab-org/gitlab-ce!22108
parents 5f3c90cd 36a73449
...@@ -66,10 +66,6 @@ class MergeRequestsFinder < IssuableFinder ...@@ -66,10 +66,6 @@ class MergeRequestsFinder < IssuableFinder
items.where(target_branch: target_branch) items.where(target_branch: target_branch)
end end
def item_project_ids(items)
items&.reorder(nil)&.select(:target_project_id)
end
def by_wip(items) def by_wip(items)
if params[:wip] == 'yes' if params[:wip] == 'yes'
items.where(wip_match(items.arel_table)) items.where(wip_match(items.arel_table))
......
...@@ -3,21 +3,37 @@ require 'spec_helper' ...@@ -3,21 +3,37 @@ require 'spec_helper'
describe MergeRequestsFinder do describe MergeRequestsFinder do
include ProjectForksHelper 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 create_project_without_n_plus_1(*args)
Gitlab::GitalyClient.allow_n_plus_1_calls do
create(:project, :public, *args)
end
end
let(:user) { create :user } let(:user) { create :user }
let(:user2) { create :user } let(:user2) { create :user }
let(:group) { create(:group) } let(:group) { create(:group) }
let(:subgroup) { create(:group, parent: group) } let(:subgroup) { create(:group, parent: group) }
let(:project1) { create(:project, :public, group: group) } let(:project1) { create_project_without_n_plus_1(group: group) }
let(:project2) { fork_project(project1, user) } let(:project2) do
Gitlab::GitalyClient.allow_n_plus_1_calls do
fork_project(project1, user)
end
end
let(:project3) do let(:project3) do
p = fork_project(project1, user) Gitlab::GitalyClient.allow_n_plus_1_calls do
p.update!(archived: true) p = fork_project(project1, user)
p p.update!(archived: true)
p
end
end end
let(:project4) { create(:project, :public, group: subgroup) } let(:project4) { create_project_without_n_plus_1(group: subgroup) }
let(:project5) { create(:project, :public, group: subgroup) } let(:project5) { create_project_without_n_plus_1(group: subgroup) }
let(:project6) { create(:project, :public, group: subgroup) } let(:project6) { create_project_without_n_plus_1(group: subgroup) }
let!(:merge_request1) { create(:merge_request, :simple, author: user, source_project: project2, target_project: project1) } let!(:merge_request1) { create(:merge_request, :simple, author: user, source_project: project2, target_project: project1) }
let!(:merge_request2) { create(:merge_request, :conflict, author: user, source_project: project2, target_project: project1, state: 'closed') } let!(:merge_request2) { create(:merge_request, :conflict, author: user, source_project: project2, target_project: project1, state: 'closed') }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment