Commit aeef33f8 authored by Robert Speicher's avatar Robert Speicher

Merge branch '273234-update-mapping-config' into 'master'

Update Elasticsearch document for issues

See merge request gitlab-org/gitlab!46916
parents ac4588fe 4e0635c6
...@@ -14,6 +14,15 @@ module Elastic ...@@ -14,6 +14,15 @@ module Elastic
data['assignee_id'] = safely_read_attribute_for_elasticsearch(:assignee_ids) data['assignee_id'] = safely_read_attribute_for_elasticsearch(:assignee_ids)
# protect against missing project_feature and set visibility to PRIVATE
# if the project_feature is missing on a project
begin
data['issues_access_level'] = target.project.project_feature.issues_access_level
rescue NoMethodError => e
Gitlab::ErrorTracking.track_exception(e, project_id: target.project_id, issue_id: target.id)
data['issues_access_level'] = ProjectFeature::PRIVATE
end
data.merge(generic_attributes) data.merge(generic_attributes)
end end
end end
......
...@@ -56,7 +56,7 @@ RSpec.describe Issue, :elastic do ...@@ -56,7 +56,7 @@ RSpec.describe Issue, :elastic do
end end
end end
it "searches issues" do it "searches issues", :aggregate_failures do
Sidekiq::Testing.inline! do Sidekiq::Testing.inline! do
create :issue, title: 'bla-bla term1', project: project create :issue, title: 'bla-bla term1', project: project
create :issue, description: 'bla-bla term2', project: project create :issue, description: 'bla-bla term2', project: project
...@@ -129,10 +129,20 @@ RSpec.describe Issue, :elastic do ...@@ -129,10 +129,20 @@ RSpec.describe Issue, :elastic do
}) })
expected_hash['assignee_id'] = [assignee.id] expected_hash['assignee_id'] = [assignee.id]
expected_hash['issues_access_level'] = issue.project.project_feature.issues_access_level
expect(issue.__elasticsearch__.as_indexed_json).to eq(expected_hash) expect(issue.__elasticsearch__.as_indexed_json).to eq(expected_hash)
end end
it 'handles a project missing project_feature' do
issue = create :issue, project: project
allow(issue.project).to receive(:project_feature).and_return(nil)
expect(Gitlab::ErrorTracking).to receive(:track_exception)
expect(issue.__elasticsearch__.as_indexed_json['issues_access_level']).to eq(ProjectFeature::PRIVATE)
end
context 'field length limits' do context 'field length limits' do
context 'when there is an elasticsearch_indexed_field_length limit' do context 'when there is an elasticsearch_indexed_field_length limit' do
it 'truncates to the default plan limit' do it 'truncates to the default plan limit' do
......
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