Commit d7bc6b82 authored by Valery Sizov's avatar Valery Sizov

Merge branch 'fix-es-search-by-iid' into 'master'

Fix search by iid when Elasticsearch is enabled

Closes #350 

See merge request !238
parents 96e6cc9c 38dc25db
......@@ -95,6 +95,16 @@ module Elastic
query_hash
end
def iid_query_hash(query_hash, iid)
{
query: {
filtered: {
query: { match: { iid: iid } }
}
}
}
end
def project_ids_filter(query_hash, project_ids)
if project_ids
query_hash[:query][:filtered][:filter] = {
......
......@@ -36,9 +36,11 @@ module Elastic
end
def self.elastic_search(query, options: {})
options[:in] = %w(title^2 description)
query_hash = basic_query_hash(options[:in], query)
if query =~ /#(\d+)\z/
query_hash = iid_query_hash(query_hash, $1)
else
query_hash = basic_query_hash(%w(title^2 description), query)
end
query_hash = project_ids_filter(query_hash, options[:projects_ids])
......
......@@ -59,7 +59,11 @@ module Elastic
end
def self.elastic_search(query, options: {})
if query =~ /#(\d+)\z/
query_hash = iid_query_hash(query_hash, $1)
else
query_hash = basic_query_hash(%w(title^2 description), query)
end
if options[:projects_ids]
query_hash[:query][:filtered][:filter] = {
......
......@@ -66,12 +66,8 @@ module Gitlab
projects_ids: limit_project_ids
}
if query =~ /#(\d+)\z/
Issue.in_projects(limit_project_ids).where(iid: $1)
else
Issue.elastic_search(query, options: opt)
end
end
def milestones
opt = {
......@@ -86,12 +82,8 @@ module Gitlab
projects_ids: limit_project_ids
}
if query =~ /[#!](\d+)\z/
MergeRequest.in_projects(limit_project_ids).where(iid: $1)
else
MergeRequest.elastic_search(query, options: opt)
end
end
def default_scope
'projects'
......
require 'spec_helper'
describe Gitlab::Elastic::SearchResults, lib: true do
before do
allow(Gitlab.config.elasticsearch).to receive(:enabled).and_return(true)
Issue.__elasticsearch__.create_index!
MergeRequest.__elasticsearch__.create_index!
end
after do
allow(Gitlab.config.elasticsearch).to receive(:enabled).and_return(false)
Issue.__elasticsearch__.delete_index!
MergeRequest.__elasticsearch__.delete_index!
end
let(:project_1) { create(:project) }
let(:project_2) { create(:project) }
let(:limit_project_ids) { [project_1.id] }
describe 'issues' do
let!(:issue_1) { create(:issue, project: project_1, title: 'Hello world, here I am!', iid: 1) }
let!(:issue_2) { create(:issue, project: project_1, title: 'Issue 2', description: 'Hello world, here I am!', iid: 2) }
let!(:issue_3) { create(:issue, project: project_2, title: 'Issue 3', iid: 2) }
before do
Issue.__elasticsearch__.refresh_index!
end
it 'should list issues that title or description contain the query' do
results = described_class.new(limit_project_ids, 'hello world')
issues = results.objects('issues')
expect(issues).to include issue_1
expect(issues).to include issue_2
expect(issues).not_to include issue_3
expect(results.issues_count).to eq 2
end
it 'should return empty list when issues title or description does not contain the query' do
results = described_class.new(limit_project_ids, 'security')
expect(results.objects('issues')).to be_empty
expect(results.issues_count).to eq 0
end
it 'should list issue when search by a valid iid' do
results = described_class.new(limit_project_ids, '#2')
issues = results.objects('issues')
expect(issues).not_to include issue_1
expect(issues).to include issue_2
expect(issues).not_to include issue_3
expect(results.issues_count).to eq 1
end
it 'should return empty list when search by invalid iid' do
results = described_class.new(limit_project_ids, '#222')
expect(results.objects('issues')).to be_empty
expect(results.issues_count).to eq 0
end
end
describe 'merge requests' do
let!(:merge_request_1) { create(:merge_request, source_project: project_1, target_project: project_1, title: 'Hello world, here I am!', iid: 1) }
let!(:merge_request_2) { create(:merge_request, :conflict, source_project: project_1, target_project: project_1, title: 'Merge Request 2', description: 'Hello world, here I am!', iid: 2) }
let!(:merge_request_3) { create(:merge_request, source_project: project_2, target_project: project_2, title: 'Merge Request 3', iid: 2) }
before do
MergeRequest.__elasticsearch__.refresh_index!
end
it 'should list merge requests that title or description contain the query' do
results = described_class.new(limit_project_ids, 'hello world')
merge_requests = results.objects('merge_requests')
expect(merge_requests).to include merge_request_1
expect(merge_requests).to include merge_request_2
expect(merge_requests).not_to include merge_request_3
expect(results.merge_requests_count).to eq 2
end
it 'should return empty list when merge requests title or description does not contain the query' do
results = described_class.new(limit_project_ids, 'security')
expect(results.objects('merge_requests')).to be_empty
expect(results.merge_requests_count).to eq 0
end
it 'should list merge request when search by a valid iid' do
results = described_class.new(limit_project_ids, '#2')
merge_requests = results.objects('merge_requests')
expect(merge_requests).not_to include merge_request_1
expect(merge_requests).to include merge_request_2
expect(merge_requests).not_to include merge_request_3
expect(results.merge_requests_count).to eq 1
end
it 'should return empty list when search by invalid iid' do
results = described_class.new(limit_project_ids, '#222')
expect(results.objects('merge_requests')).to be_empty
expect(results.merge_requests_count).to eq 0
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