summaryrefslogtreecommitdiff
path: root/spec/requests/api
diff options
context:
space:
mode:
authorJarka Kadlecová <jarka@gitlab.com>2018-01-15 13:06:42 +0100
committerJarka Kadlecová <jarka@gitlab.com>2018-01-15 13:06:42 +0100
commit4f83ef5a370bdae2b94f3fba963a100a68381dba (patch)
tree0a725113e51721bd38ec8f80415821911e721ad8 /spec/requests/api
parent2de8fb7bab49c1a5168ee56fc12e1f3ceb0ad1c7 (diff)
downloadgitlab-ce-41958-events-performance.tar.gz
Avoid N+1 queries when fetching events from the API41958-events-performance
Diffstat (limited to 'spec/requests/api')
-rw-r--r--spec/requests/api/events_spec.rb18
1 files changed, 18 insertions, 0 deletions
diff --git a/spec/requests/api/events_spec.rb b/spec/requests/api/events_spec.rb
index 962c845f36d..6696fb69273 100644
--- a/spec/requests/api/events_spec.rb
+++ b/spec/requests/api/events_spec.rb
@@ -160,6 +160,24 @@ describe API::Events do
expect(json_response.size).to eq(1)
end
+ it 'does not perform N+1 queries' do
+ endpoint = api("/projects/#{private_project.id}/events?action=closed", user)
+
+ issue = create(:issue, project: private_project)
+ note = create(:note, project: private_project, noteable: issue)
+ create(:event, project:private_project, target: note, action: Event::CLOSED)
+
+ control_count = ActiveRecord::QueryRecorder.new { get endpoint }.count
+
+ issues = create_list(:issue, 5, project: private_project)
+ issues.each do |issue|
+ note = create(:note, project: private_project, noteable: issue)
+ create(:event, project:private_project, target: note, action: Event::CLOSED)
+ end
+
+ expect { get endpoint }.not_to exceed_query_limit(control_count)
+ end
+
it 'returns 404 if project does not exist' do
get api("/projects/1234/events", user)