Commit dbf3fa07 authored by James Lopez's avatar James Lopez

Merge branch '32455-merge-request-discussions-api-degrades-with-comments-count' into 'master'

Improve pagination of Discussions API

See merge request gitlab-org/gitlab!27697
parents f16e8f57 693aa9d6
...@@ -79,6 +79,12 @@ module Noteable ...@@ -79,6 +79,12 @@ module Noteable
.discussions(self) .discussions(self)
end end
def discussion_ids_relation
notes.select(:discussion_id)
.group(:discussion_id)
.order('MIN(created_at), MIN(id)')
end
def capped_notes_count(max) def capped_notes_count(max)
notes.limit(max).count notes.limit(max).count
end end
......
---
title: Improve pagination in discussions API
merge_request: 27697
author:
type: performance
...@@ -28,10 +28,10 @@ module API ...@@ -28,10 +28,10 @@ module API
get ":id/#{noteables_path}/:noteable_id/discussions" do get ":id/#{noteables_path}/:noteable_id/discussions" do
noteable = find_noteable(noteable_type, params[:noteable_id]) noteable = find_noteable(noteable_type, params[:noteable_id])
notes = readable_discussion_notes(noteable) discussion_ids = paginate(noteable.discussion_ids_relation)
discussions = Kaminari.paginate_array(Discussion.build_collection(notes, noteable)) notes = readable_discussion_notes(noteable, discussion_ids)
present paginate(discussions), with: Entities::Discussion present Discussion.build_collection(notes, noteable), with: Entities::Discussion
end end
desc "Get a single #{noteable_type.to_s.downcase} discussion" do desc "Get a single #{noteable_type.to_s.downcase} discussion" do
...@@ -221,10 +221,9 @@ module API ...@@ -221,10 +221,9 @@ module API
helpers do helpers do
# rubocop: disable CodeReuse/ActiveRecord # rubocop: disable CodeReuse/ActiveRecord
def readable_discussion_notes(noteable, discussion_id = nil) def readable_discussion_notes(noteable, discussion_ids)
notes = noteable.notes notes = noteable.notes
notes = notes.where(discussion_id: discussion_id) if discussion_id .where(discussion_id: discussion_ids)
notes = notes
.inc_relations_for_view .inc_relations_for_view
.includes(:noteable) .includes(:noteable)
.fresh .fresh
......
...@@ -62,6 +62,21 @@ describe Noteable do ...@@ -62,6 +62,21 @@ describe Noteable do
end end
end end
describe '#discussion_ids_relation' do
it 'returns ordered discussion_ids' do
discussion_ids = subject.discussion_ids_relation.pluck(:discussion_id)
expect(discussion_ids).to eq([
active_diff_note1,
active_diff_note3,
outdated_diff_note1,
discussion_note1,
note1,
note2
].map(&:discussion_id))
end
end
describe '#grouped_diff_discussions' do describe '#grouped_diff_discussions' do
let(:grouped_diff_discussions) { subject.grouped_diff_discussions } let(:grouped_diff_discussions) { subject.grouped_diff_discussions }
......
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