diff options
author | Yorick Peterse <yorickpeterse@gmail.com> | 2018-04-19 12:51:51 +0000 |
---|---|---|
committer | Yorick Peterse <yorickpeterse@gmail.com> | 2018-04-19 12:51:51 +0000 |
commit | a313aeceeeb20802ff9311199c839380414a588f (patch) | |
tree | ff45c2b9783a28fac95363b729f9d38e7e77acf4 /spec/models | |
parent | 9cc011fdedab44f7423ed24150c93117abc689aa (diff) | |
parent | 775211bc7076bba14d6e268fb324391124a2751f (diff) | |
download | gitlab-ce-a313aeceeeb20802ff9311199c839380414a588f.tar.gz |
Merge branch 'sh-fix-award-emoji-nplus-one-participants' into 'master'
Fix N+1 queries when loading participants for a commit note
Closes #45526
See merge request gitlab-org/gitlab-ce!18471
Diffstat (limited to 'spec/models')
-rw-r--r-- | spec/models/note_spec.rb | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/spec/models/note_spec.rb b/spec/models/note_spec.rb index 86962cd8d61..6a6c71e6c82 100644 --- a/spec/models/note_spec.rb +++ b/spec/models/note_spec.rb @@ -91,6 +91,23 @@ describe Note do it "keeps the commit around" do expect(note.project.repository.kept_around?(commit.id)).to be_truthy end + + it 'does not generate N+1 queries for participants', :request_store do + def retrieve_participants + commit.notes_with_associations.map(&:participants).to_a + end + + # Project authorization checks are cached, establish a baseline + retrieve_participants + + control_count = ActiveRecord::QueryRecorder.new do + retrieve_participants + end + + create(:note_on_commit, project: note.project, note: 'another note', noteable_id: commit.id) + + expect { retrieve_participants }.not_to exceed_query_limit(control_count) + end end describe 'authorization' do |