Improve performance ee/spec/services/search/snippet_service_spec.rb

parent 63f1c564
...@@ -8,7 +8,7 @@ RSpec.describe Search::SnippetService do ...@@ -8,7 +8,7 @@ RSpec.describe Search::SnippetService do
using RSpec::Parameterized::TableSyntax using RSpec::Parameterized::TableSyntax
it_behaves_like 'EE search service shared examples', ::Gitlab::SnippetSearchResults, ::Gitlab::Elastic::SnippetSearchResults do it_behaves_like 'EE search service shared examples', ::Gitlab::SnippetSearchResults, ::Gitlab::Elastic::SnippetSearchResults do
let(:user) { create(:user) } let_it_be(:user) { create(:user) }
let(:scope) { nil } let(:scope) { nil }
let(:service) { described_class.new(user, params) } let(:service) { described_class.new(user, params) }
end end
...@@ -24,7 +24,11 @@ RSpec.describe Search::SnippetService do ...@@ -24,7 +24,11 @@ RSpec.describe Search::SnippetService do
include_context 'ProjectPolicyTable context' include_context 'ProjectPolicyTable context'
include ProjectHelpers include ProjectHelpers
let(:search_term) { 'foobar' } let_it_be(:admin) { create(:admin) }
let_it_be(:other_user) { create(:user) }
let_it_be(:reporter) { create(:user) }
let_it_be(:guest) { create(:user) }
let_it_be(:snippet_author) { create(:user) }
context 'project snippet' do context 'project snippet' do
let(:pendings) do let(:pendings) do
...@@ -47,62 +51,89 @@ RSpec.describe Search::SnippetService do ...@@ -47,62 +51,89 @@ RSpec.describe Search::SnippetService do
) )
end end
let_it_be(:group) { create(:group) } let_it_be(:group) { create(:group) }
let!(:project) { create(:project, project_level, namespace: group) } let_it_be(:project, refind: true) do
let!(:snippet) { create(:project_snippet, snippet_level, project: project, title: search_term, content: search_term) } create(:project, :public, namespace: group).tap do |p|
let(:user) { create_user_from_membership(project, membership) } p.add_user(reporter, :reporter)
p.add_user(guest, :guest)
end
end
let_it_be(:snippet) { create(:project_snippet, :public, project: project, author: snippet_author, title: 'foobar') }
where(:snippet_level, :project_level, :feature_access_level, :membership, :expected_count) do where(:snippet_level, :project_level, :feature_access_level, :membership, :expected_count) do
permission_table_for_project_snippet_access permission_table_for_project_snippet_access
end end
with_them do with_them do
it "respects visibility" do it 'respects visibility' do
update_feature_access_level(project, feature_access_level) project.update!(visibility_level: Gitlab::VisibilityLevel.level_value(project_level.to_s), snippets_access_level: feature_access_level)
snippet.update!(visibility_level: Gitlab::VisibilityLevel.level_value(snippet_level.to_s))
ensure_elasticsearch_index! ensure_elasticsearch_index!
expected_objects = expected_count == 0 ? [] : [snippet] expected_objects = expected_count == 0 ? [] : [snippet]
expect_search_results(user, 'snippet_titles', expected_objects: expected_objects, pending: pending?) do |user| search_user = user_from_membership(membership)
described_class.new(user, search: search_term).execute
end
expect_search_results(user, 'snippet_blobs', expected_objects: expected_objects, pending: pending?) do |user| expect_search_results(search_user, 'snippet_titles', expected_objects: expected_objects, pending: pending?) do |user|
described_class.new(user, search: search_term).execute described_class.new(user, search: snippet.title).execute
end end
end end
end end
end end
context 'personal snippet' do context 'personal snippet' do
let(:user) do let_it_be(:public_snippet) { create(:personal_snippet, :public, title: 'This is a public snippet', author: snippet_author) }
if membership == :author let_it_be(:private_snippet) { create(:personal_snippet, :private, title: 'This is a private snippet', author: snippet_author) }
snippet.author let_it_be(:internal_snippet) { create(:personal_snippet, :internal, title: 'This is a internal snippet', author: snippet_author) }
else
create_user_from_membership(nil, membership) let(:snippets) do
end {
public: public_snippet,
private: private_snippet,
internal: internal_snippet
}
end end
let!(:snippet) { create(:personal_snippet, snippet_level, title: search_term, content: search_term) }
let(:snippet) { snippets[snippet_level] }
where(:snippet_level, :membership, :expected_count) do where(:snippet_level, :membership, :expected_count) do
permission_table_for_personal_snippet_access permission_table_for_personal_snippet_access
end end
with_them do with_them do
it "respects visibility" do it 'respects visibility' do
# When the snippets are created the ES settings are not enabled
# and we need to manually add them to ES for indexing.
::Elastic::ProcessBookkeepingService.track!(snippet)
ensure_elasticsearch_index! ensure_elasticsearch_index!
expected_objects = expected_count == 0 ? [] : [snippet] expected_objects = expected_count == 0 ? [] : [snippet]
expect_search_results(user, 'snippet_titles', expected_objects: expected_objects) do |user| search_user = user_from_membership(membership)
described_class.new(user, search: search_term).execute
end
expect_search_results(user, 'snippet_blobs', expected_objects: expected_objects) do |user| expect_search_results(search_user, 'snippet_titles', expected_objects: expected_objects) do |user|
described_class.new(user, search: search_term).execute described_class.new(user, search: snippet.title).execute
end end
end end
end end
end end
def user_from_membership(membership)
case membership
when :author
snippet.author
when :anonymous
nil
when :non_member
other_user
when :admin
admin
when :reporter
reporter
else
guest
end
end
end end
end end
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