debian-mirror-gitlab/spec/support/helpers/reference_parser_helpers.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

52 lines
1.6 KiB
Ruby
Raw Normal View History

2019-10-12 21:52:04 +05:30
# frozen_string_literal: true
module ReferenceParserHelpers
def empty_html_link
Nokogiri::HTML.fragment('<a></a>').children[0]
end
2018-05-09 12:01:36 +05:30
2021-11-11 11:23:49 +05:30
def expect_gathered_references(result, visible, nodes, visible_nodes)
2020-02-01 01:16:34 +05:30
expect(result[:visible]).to eq(visible)
2021-11-11 11:23:49 +05:30
expect(result[:nodes]).to eq(nodes)
expect(result[:visible_nodes]).to eq(visible_nodes)
2020-02-01 01:16:34 +05:30
end
2020-07-28 23:09:34 +05:30
RSpec.shared_examples 'no project N+1 queries' do
2021-09-04 01:27:46 +05:30
it 'avoids N+1 queries in #nodes_visible_to_user' do
2018-05-09 12:01:36 +05:30
context = Banzai::RenderContext.new(project, user)
2021-09-04 01:27:46 +05:30
request = lambda do |links|
described_class.new(context).nodes_visible_to_user(user, links)
2018-05-09 12:01:36 +05:30
end
2021-09-04 01:27:46 +05:30
control = ActiveRecord::QueryRecorder.new { request.call(control_links) }
2018-05-09 12:01:36 +05:30
2021-09-04 01:27:46 +05:30
create(:group_member, group: project.group) if project.group
create(:project_member, project: project)
create(:project_group_link, project: project)
expect { request.call(actual_links) }.not_to exceed_query_limit(control)
2018-05-09 12:01:36 +05:30
end
2018-12-05 23:21:45 +05:30
end
2020-07-28 23:09:34 +05:30
RSpec.shared_examples 'no N+1 queries' do
2018-12-05 23:21:45 +05:30
it_behaves_like 'no project N+1 queries'
2018-05-09 12:01:36 +05:30
it 'avoids N+1 queries in #records_for_nodes', :request_store do
context = Banzai::RenderContext.new(project, user)
record_queries = lambda do |links|
ActiveRecord::QueryRecorder.new do
described_class.new(context).records_for_nodes(links)
end
end
control = record_queries.call(control_links)
actual = record_queries.call(actual_links)
expect(actual.count).to be <= control.count
expect(actual.cached_count).to be <= control.cached_count
end
end
end