Commit d7cdc772 authored by Dylan Griffith's avatar Dylan Griffith

Merge branch 'duplicate_autocomplete_suggestions' into 'master'

Fix missing item with same name in autocomplete suggestions

See merge request gitlab-org/gitlab!48410
parents 8820fc6c d95c3d22
...@@ -31,7 +31,7 @@ module SearchHelper ...@@ -31,7 +31,7 @@ module SearchHelper
[ [
resources_results, resources_results,
generic_results generic_results
].flatten.uniq do |item| ].flatten do |item|
item[:label] item[:label]
end end
end end
......
---
title: Fix missing item with same name in autocomplete suggestions
merge_request: 48410
author: Paul Ungureanu @ungps
type: fixed
...@@ -104,6 +104,37 @@ RSpec.describe SearchHelper do ...@@ -104,6 +104,37 @@ RSpec.describe SearchHelper do
}) })
end end
it 'includes the users recently viewed issues with the exact same name', :aggregate_failures do
recent_issues = instance_double(::Gitlab::Search::RecentIssues)
expect(::Gitlab::Search::RecentIssues).to receive(:new).with(user: user).and_return(recent_issues)
project1 = create(:project, namespace: user.namespace)
project2 = create(:project, namespace: user.namespace)
issue1 = create(:issue, title: 'issue same_name', project: project1)
issue2 = create(:issue, title: 'issue same_name', project: project2)
expect(recent_issues).to receive(:search).with('the search term').and_return(Issue.id_in_ordered([issue1.id, issue2.id]))
results = search_autocomplete_opts("the search term")
expect(results.count).to eq(2)
expect(results[0]).to include({
category: 'Recent issues',
id: issue1.id,
label: 'issue same_name',
url: Gitlab::Routing.url_helpers.project_issue_path(issue1.project, issue1),
avatar_url: '' # This project didn't have an avatar so set this to ''
})
expect(results[1]).to include({
category: 'Recent issues',
id: issue2.id,
label: 'issue same_name',
url: Gitlab::Routing.url_helpers.project_issue_path(issue2.project, issue2),
avatar_url: '' # This project didn't have an avatar so set this to ''
})
end
it 'includes the users recently viewed merge requests', :aggregate_failures do it 'includes the users recently viewed merge requests', :aggregate_failures do
recent_merge_requests = instance_double(::Gitlab::Search::RecentMergeRequests) recent_merge_requests = instance_double(::Gitlab::Search::RecentMergeRequests)
expect(::Gitlab::Search::RecentMergeRequests).to receive(:new).with(user: user).and_return(recent_merge_requests) expect(::Gitlab::Search::RecentMergeRequests).to receive(:new).with(user: user).and_return(recent_merge_requests)
......
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