Commit a241581c authored by nmilojevic1's avatar nmilojevic1

Add specs for cached queries

- Add changelog
parent 76f8c168
---
title: Reduce 'cached' query calls for Banzai
merge_request: 36735
author:
type: performance
...@@ -31,6 +31,19 @@ RSpec.describe Banzai::Filter::LabelReferenceFilter do ...@@ -31,6 +31,19 @@ RSpec.describe Banzai::Filter::LabelReferenceFilter do
expect(doc.css('a').first.attr('class')).to eq 'gfm gfm-label has-tooltip gl-link gl-label-link' expect(doc.css('a').first.attr('class')).to eq 'gfm gfm-label has-tooltip gl-link gl-label-link'
end end
it 'avoids N+1 cached queries', :use_sql_query_cache, :request_store do
# Run this once to establish a baseline
reference_filter("Label #{reference}")
control_count = ActiveRecord::QueryRecorder.new(skip_cached: false) do
reference_filter("Label #{reference}")
end
labels_markdown = Array.new(10, "Label #{reference}").join('\n')
expect { reference_filter(labels_markdown) }.not_to exceed_all_query_limit(control_count.count)
end
it 'includes a data-project attribute' do it 'includes a data-project attribute' do
doc = reference_filter("Label #{reference}") doc = reference_filter("Label #{reference}")
link = doc.css('a').first link = doc.css('a').first
......
...@@ -33,6 +33,17 @@ RSpec.describe Banzai::ReferenceParser::SnippetParser do ...@@ -33,6 +33,17 @@ RSpec.describe Banzai::ReferenceParser::SnippetParser do
project.project_feature.update_attribute(:snippets_access_level, ProjectFeature::ENABLED) project.project_feature.update_attribute(:snippets_access_level, ProjectFeature::ENABLED)
end end
it 'avoids N+1 cached queries', :use_sql_query_cache do
# Run this once to establish a baseline
visible_references(:public)
control_count = ActiveRecord::QueryRecorder.new(skip_cached: false) do
subject.nodes_visible_to_user(user, [link])
end
expect { subject.nodes_visible_to_user(user, Array.new(10, link)) }.not_to exceed_all_query_limit(control_count.count)
end
it 'creates a reference for guest for a public snippet' do it 'creates a reference for guest for a public snippet' do
expect(visible_references(:public)).to eq([link]) expect(visible_references(:public)).to eq([link])
end end
......
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