Commit 693aa9d6 authored by Heinrich Lee Yu's avatar Heinrich Lee Yu

Improve performance of discussions API

Paginates discussions from the DB so that we don't have to do
Markdown processing on all the notes.
parent 438e0332
...@@ -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