Commit 74fec15a authored by Igor Drozdov's avatar Igor Drozdov

Return code navigation path for nil diff_refs

Also hide CodeNavigation service behind a feature flag
This will allow us to disable calling the service if anything
goes wrong
parent 9b596143
...@@ -69,11 +69,9 @@ class DiffsEntity < Grape::Entity ...@@ -69,11 +69,9 @@ class DiffsEntity < Grape::Entity
expose :diff_files do |diffs, options| expose :diff_files do |diffs, options|
submodule_links = Gitlab::SubmoduleLinks.new(merge_request.project.repository) submodule_links = Gitlab::SubmoduleLinks.new(merge_request.project.repository)
code_navigation_path =
Gitlab::CodeNavigationPath.new(merge_request.project, diffs.diff_refs.head_sha)
DiffFileEntity.represent(diffs.diff_files, DiffFileEntity.represent(diffs.diff_files,
options.merge(submodule_links: submodule_links, code_navigation_path: code_navigation_path)) options.merge(submodule_links: submodule_links, code_navigation_path: code_navigation_path(diffs)))
end end
expose :merge_request_diffs, using: MergeRequestDiffEntity, if: -> (_, options) { options[:merge_request_diffs]&.any? } do |diffs| expose :merge_request_diffs, using: MergeRequestDiffEntity, if: -> (_, options) { options[:merge_request_diffs]&.any? } do |diffs|
...@@ -81,7 +79,7 @@ class DiffsEntity < Grape::Entity ...@@ -81,7 +79,7 @@ class DiffsEntity < Grape::Entity
end end
expose :definition_path_prefix, if: -> (diff_file) { Feature.enabled?(:code_navigation, merge_request.project) } do |diffs| expose :definition_path_prefix, if: -> (diff_file) { Feature.enabled?(:code_navigation, merge_request.project) } do |diffs|
project_blob_path(merge_request.project, diffs.diff_refs.head_sha) project_blob_path(merge_request.project, diffs.diff_refs&.head_sha)
end end
def merge_request def merge_request
...@@ -90,6 +88,12 @@ class DiffsEntity < Grape::Entity ...@@ -90,6 +88,12 @@ class DiffsEntity < Grape::Entity
private private
def code_navigation_path(diffs)
return unless Feature.enabled?(:code_navigation, merge_request.project)
Gitlab::CodeNavigationPath.new(merge_request.project, diffs.diff_refs&.head_sha)
end
def commit_ids def commit_ids
@commit_ids ||= merge_request.recent_commits.map(&:id) @commit_ids ||= merge_request.recent_commits.map(&:id)
end end
......
...@@ -10,11 +10,9 @@ class PaginatedDiffEntity < Grape::Entity ...@@ -10,11 +10,9 @@ class PaginatedDiffEntity < Grape::Entity
expose :diff_files do |diffs, options| expose :diff_files do |diffs, options|
submodule_links = Gitlab::SubmoduleLinks.new(merge_request.project.repository) submodule_links = Gitlab::SubmoduleLinks.new(merge_request.project.repository)
code_navigation_path =
Gitlab::CodeNavigationPath.new(merge_request.project, diffs.diff_refs.head_sha)
DiffFileEntity.represent(diffs.diff_files, DiffFileEntity.represent(diffs.diff_files,
options.merge(submodule_links: submodule_links, code_navigation_path: code_navigation_path)) options.merge(submodule_links: submodule_links, code_navigation_path: code_navigation_path(diffs)))
end end
expose :pagination do expose :pagination do
...@@ -38,6 +36,12 @@ class PaginatedDiffEntity < Grape::Entity ...@@ -38,6 +36,12 @@ class PaginatedDiffEntity < Grape::Entity
private private
def code_navigation_path(diffs)
return unless Feature.enabled?(:code_navigation, merge_request.project)
Gitlab::CodeNavigationPath.new(merge_request.project, diffs.diff_refs&.head_sha)
end
%i[current_page next_page total_pages].each do |method| %i[current_page next_page total_pages].each do |method|
define_method method do define_method method do
pagination_data[method] pagination_data[method]
......
---
title: Return code navigation path for nil diff_refs
merge_request: 33850
author:
type: fixed
...@@ -12,6 +12,7 @@ describe Gitlab::CodeNavigationPath do ...@@ -12,6 +12,7 @@ describe Gitlab::CodeNavigationPath do
let(:commit_sha) { sha } let(:commit_sha) { sha }
let(:path) { 'lib/app.rb' } let(:path) { 'lib/app.rb' }
let(:lsif_path) { "/#{project.full_path}/-/jobs/#{job.id}/artifacts/raw/lsif/#{path}.json?file_type=lsif" }
subject { described_class.new(project, commit_sha).full_json_path_for(path) } subject { described_class.new(project, commit_sha).full_json_path_for(path) }
...@@ -21,7 +22,15 @@ describe Gitlab::CodeNavigationPath do ...@@ -21,7 +22,15 @@ describe Gitlab::CodeNavigationPath do
context 'when a pipeline exist for a sha' do context 'when a pipeline exist for a sha' do
it 'returns path to a file in the artifact' do it 'returns path to a file in the artifact' do
expect(subject).to eq("/#{project.full_path}/-/jobs/#{job.id}/artifacts/raw/lsif/#{path}.json?file_type=lsif") expect(subject).to eq(lsif_path)
end
context 'when passed commit sha is nil' do
let(:commit_sha) { nil }
it 'returns path to a file in the artifact' do
expect(subject).to eq(lsif_path)
end
end end
end end
...@@ -29,7 +38,7 @@ describe Gitlab::CodeNavigationPath do ...@@ -29,7 +38,7 @@ describe Gitlab::CodeNavigationPath do
let(:commit_sha) { project.commit.id } let(:commit_sha) { project.commit.id }
it 'returns path to a file in the artifact' do it 'returns path to a file in the artifact' do
expect(subject).to eq("/#{project.full_path}/-/jobs/#{job.id}/artifacts/raw/lsif/#{path}.json?file_type=lsif") expect(subject).to eq(lsif_path)
end end
end end
......
...@@ -68,5 +68,15 @@ describe DiffsEntity do ...@@ -68,5 +68,15 @@ describe DiffsEntity do
end end
end end
end end
context 'when code_navigation feature flag is disabled' do
it 'does not include code navigation properties' do
stub_feature_flags(code_navigation: false)
expect(Gitlab::CodeNavigationPath).not_to receive(:new)
expect(subject).not_to include(:definition_path_prefix)
end
end
end end
end end
...@@ -30,4 +30,14 @@ describe PaginatedDiffEntity do ...@@ -30,4 +30,14 @@ describe PaginatedDiffEntity do
total_pages: 7 total_pages: 7
) )
end end
context 'when code_navigation feature flag is disabled' do
it 'does not execute Gitlab::CodeNavigationPath' do
stub_feature_flags(code_navigation: false)
expect(Gitlab::CodeNavigationPath).not_to receive(:new)
subject
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