Commit a0d9e943 authored by Olivier Gonzalez's avatar Olivier Gonzalez

Support both new and old artifact name for code quality

parent 3081b265
...@@ -7,7 +7,9 @@ module EE ...@@ -7,7 +7,9 @@ module EE
module Build module Build
extend ActiveSupport::Concern extend ActiveSupport::Concern
CODEQUALITY_FILE = 'gl-code-quality-report.json'.freeze # CODECLIMATE_FILE is deprecated and replaced with CODE_QUALITY_FILE (#5779)
CODECLIMATE_FILE = 'codeclimate.json'.freeze
CODE_QUALITY_FILE = 'gl-code-quality-report.json'.freeze
DEPENDENCY_SCANNING_FILE = 'gl-dependency-scanning-report.json'.freeze DEPENDENCY_SCANNING_FILE = 'gl-dependency-scanning-report.json'.freeze
LICENSE_MANAGEMENT_FILE = 'gl-license-report.json'.freeze LICENSE_MANAGEMENT_FILE = 'gl-license-report.json'.freeze
SAST_FILE = 'gl-sast-report.json'.freeze SAST_FILE = 'gl-sast-report.json'.freeze
...@@ -18,7 +20,9 @@ module EE ...@@ -18,7 +20,9 @@ module EE
DAST_FILE = 'gl-dast-report.json'.freeze DAST_FILE = 'gl-dast-report.json'.freeze
included do included do
scope :codequality, -> { where(name: %w[code_quality codequality]) } # codeclimate is deprecated and replaced with code_quality (#5779)
scope :codeclimate, -> { where(name: %w[codeclimate codequality]) }
scope :code_quality, -> { where(name: 'code_quality') }
scope :performance, -> { where(name: %w[performance deploy]) } scope :performance, -> { where(name: %w[performance deploy]) }
scope :sast, -> { where(name: 'sast') } scope :sast, -> { where(name: 'sast') }
scope :dependency_scanning, -> { where(name: 'dependency_scanning') } scope :dependency_scanning, -> { where(name: 'dependency_scanning') }
...@@ -46,8 +50,13 @@ module EE ...@@ -46,8 +50,13 @@ module EE
::Gitlab::Database::LoadBalancing::Sticking.stick(:build, id) ::Gitlab::Database::LoadBalancing::Sticking.stick(:build, id)
end end
# has_codeclimate_json? is deprecated and replaced with has_code_quality_json? (#5779)
def has_codeclimate_json? def has_codeclimate_json?
has_artifact?(CODEQUALITY_FILE) has_artifact?(CODECLIMATE_FILE)
end
def has_code_quality_json?
has_artifact?(CODE_QUALITY_FILE)
end end
def has_performance_json? def has_performance_json?
......
...@@ -12,8 +12,13 @@ module EE ...@@ -12,8 +12,13 @@ module EE
has_one :chat_data, class_name: 'Ci::PipelineChatData' has_one :chat_data, class_name: 'Ci::PipelineChatData'
end end
# codeclimate_artifact is deprecated and replaced with code_quality_artifact (#5779)
def codeclimate_artifact def codeclimate_artifact
@codeclimate_artifact ||= artifacts.codequality.find(&:has_codeclimate_json?) @codeclimate_artifact ||= artifacts.codeclimate.find(&:has_codeclimate_json?)
end
def code_quality_artifact
@code_quality_artifact ||= artifacts.code_quality.find(&:has_code_quality_json?)
end end
def performance_artifact def performance_artifact
...@@ -78,10 +83,15 @@ module EE ...@@ -78,10 +83,15 @@ module EE
performance_artifact&.success? performance_artifact&.success?
end end
# has_codeclimate_data? is deprecated and replaced with has_code_quality_data? (#5779)
def has_codeclimate_data? def has_codeclimate_data?
codeclimate_artifact&.success? codeclimate_artifact&.success?
end end
def has_code_quality_data?
code_quality_artifact&.success?
end
def expose_sast_data? def expose_sast_data?
project.feature_available?(:sast) && project.feature_available?(:sast) &&
has_sast_data? has_sast_data?
...@@ -118,9 +128,14 @@ module EE ...@@ -118,9 +128,14 @@ module EE
has_performance_data? has_performance_data?
end end
# expose_codeclimate_data? is deprecated and replaced with expose_code_quality_data? (#5779)
def expose_codeclimate_data? def expose_codeclimate_data?
has_codeclimate_data? has_codeclimate_data?
end end
def expose_code_quality_data?
has_code_quality_data?
end
end end
end end
end end
...@@ -10,8 +10,11 @@ module EE ...@@ -10,8 +10,11 @@ module EE
has_many :approvers, as: :target, dependent: :delete_all # rubocop:disable Cop/ActiveRecordDependent has_many :approvers, as: :target, dependent: :delete_all # rubocop:disable Cop/ActiveRecordDependent
has_many :approver_groups, as: :target, dependent: :delete_all # rubocop:disable Cop/ActiveRecordDependent has_many :approver_groups, as: :target, dependent: :delete_all # rubocop:disable Cop/ActiveRecordDependent
# codeclimate_artifact is deprecated and replaced with code_quality_artifact (#5779)
delegate :codeclimate_artifact, to: :head_pipeline, prefix: :head, allow_nil: true delegate :codeclimate_artifact, to: :head_pipeline, prefix: :head, allow_nil: true
delegate :codeclimate_artifact, to: :base_pipeline, prefix: :base, allow_nil: true delegate :codeclimate_artifact, to: :base_pipeline, prefix: :base, allow_nil: true
delegate :code_quality_artifact, to: :head_pipeline, prefix: :head, allow_nil: true
delegate :code_quality_artifact, to: :base_pipeline, prefix: :base, allow_nil: true
delegate :performance_artifact, to: :head_pipeline, prefix: :head, allow_nil: true delegate :performance_artifact, to: :head_pipeline, prefix: :head, allow_nil: true
delegate :performance_artifact, to: :base_pipeline, prefix: :base, allow_nil: true delegate :performance_artifact, to: :base_pipeline, prefix: :base, allow_nil: true
delegate :sast_artifact, to: :head_pipeline, prefix: :head, allow_nil: true delegate :sast_artifact, to: :head_pipeline, prefix: :head, allow_nil: true
...@@ -61,11 +64,17 @@ module EE ...@@ -61,11 +64,17 @@ module EE
false false
end end
# expose_codeclimate_data? is deprecated and replaced with expose_code_quality_data? (#5779)
def expose_codeclimate_data? def expose_codeclimate_data?
!!(head_pipeline&.expose_codeclimate_data? && !!(head_pipeline&.expose_codeclimate_data? &&
base_pipeline&.expose_codeclimate_data?) base_pipeline&.expose_codeclimate_data?)
end end
def expose_code_quality_data?
!!(head_pipeline&.expose_code_quality_data? &&
base_pipeline&.expose_code_quality_data?)
end
def expose_performance_data? def expose_performance_data?
!!(head_pipeline&.expose_performance_data? && !!(head_pipeline&.expose_performance_data? &&
base_pipeline&.expose_performance_data?) base_pipeline&.expose_performance_data?)
......
...@@ -13,17 +13,33 @@ module EE ...@@ -13,17 +13,33 @@ module EE
end end
end end
# expose_codeclimate_data? is deprecated and replaced with expose_code_quality_data?
expose :codeclimate, if: -> (mr, _) { mr.expose_codeclimate_data? } do expose :codeclimate, if: -> (mr, _) { mr.expose_codeclimate_data? } do
expose :head_path, if: -> (mr, _) { can?(current_user, :read_build, mr.head_codeclimate_artifact) } do |merge_request| expose :head_path, if: -> (mr, _) { can?(current_user, :read_build, mr.head_codeclimate_artifact) } do |merge_request|
raw_project_build_artifacts_url(merge_request.source_project, raw_project_build_artifacts_url(merge_request.source_project,
merge_request.head_codeclimate_artifact, merge_request.head_codeclimate_artifact,
path: Ci::Build::CODEQUALITY_FILE) path: Ci::Build::CODECLIMATE_FILE)
end end
expose :base_path, if: -> (mr, _) { can?(current_user, :read_build, mr.base_codeclimate_artifact) } do |merge_request| expose :base_path, if: -> (mr, _) { can?(current_user, :read_build, mr.base_codeclimate_artifact) } do |merge_request|
raw_project_build_artifacts_url(merge_request.target_project, raw_project_build_artifacts_url(merge_request.target_project,
merge_request.base_codeclimate_artifact, merge_request.base_codeclimate_artifact,
path: Ci::Build::CODEQUALITY_FILE) path: Ci::Build::CODECLIMATE_FILE)
end
end
# We still expose it as `codeclimate` to keep compatibility with Frontend
expose :codeclimate, if: -> (mr, _) { mr.expose_code_quality_data? } do
expose :head_path, if: -> (mr, _) { can?(current_user, :read_build, mr.head_code_quality_artifact) } do |merge_request|
raw_project_build_artifacts_url(merge_request.source_project,
merge_request.head_code_quality_artifact,
path: Ci::Build::CODE_QUALITY_FILE)
end
expose :base_path, if: -> (mr, _) { can?(current_user, :read_build, mr.base_code_quality_artifact) } do |merge_request|
raw_project_build_artifacts_url(merge_request.target_project,
merge_request.base_code_quality_artifact,
path: Ci::Build::CODE_QUALITY_FILE)
end end
end end
......
...@@ -13,11 +13,12 @@ describe Ci::Build do ...@@ -13,11 +13,12 @@ describe Ci::Build do
let(:job) { create(:ci_build, pipeline: pipeline) } let(:job) { create(:ci_build, pipeline: pipeline) }
describe '.codequality' do # .codeclimate is deprecated and replaced with .code_quality_artifact (#5779)
subject { described_class.codequality } describe '.codeclimate' do
subject { described_class.codeclimate }
context 'when a job name is code_quality' do context 'when a job name is codeclimate' do
let!(:job) { create(:ci_build, pipeline: pipeline, name: 'code_quality') } let!(:job) { create(:ci_build, pipeline: pipeline, name: 'codeclimate') }
it { is_expected.to include(job) } it { is_expected.to include(job) }
end end
...@@ -35,6 +36,22 @@ describe Ci::Build do ...@@ -35,6 +36,22 @@ describe Ci::Build do
end end
end end
describe '.code_quality' do
subject { described_class.code_quality }
context 'when a job name is code_quality' do
let!(:job) { create(:ci_build, pipeline: pipeline, name: 'code_quality') }
it { is_expected.to include(job) }
end
context 'when a job name is irrelevant' do
let!(:job) { create(:ci_build, pipeline: pipeline, name: 'codechecker') }
it { is_expected.not_to include(job) }
end
end
describe '#shared_runners_minutes_limit_enabled?' do describe '#shared_runners_minutes_limit_enabled?' do
subject { job.shared_runners_minutes_limit_enabled? } subject { job.shared_runners_minutes_limit_enabled? }
...@@ -138,7 +155,9 @@ describe Ci::Build do ...@@ -138,7 +155,9 @@ describe Ci::Build do
end end
BUILD_ARTIFACTS_METHODS = { BUILD_ARTIFACTS_METHODS = {
has_codeclimate_json?: Ci::Build::CODEQUALITY_FILE, # has_codeclimate_json? is deprecated and replaced with code_quality_artifact (#5779)
has_codeclimate_json?: Ci::Build::CODECLIMATE_FILE,
has_code_quality_json?: Ci::Build::CODE_QUALITY_FILE,
has_performance_json?: Ci::Build::PERFORMANCE_FILE, has_performance_json?: Ci::Build::PERFORMANCE_FILE,
has_sast_json?: Ci::Build::SAST_FILE, has_sast_json?: Ci::Build::SAST_FILE,
has_dependency_scanning_json?: Ci::Build::DEPENDENCY_SCANNING_FILE, has_dependency_scanning_json?: Ci::Build::DEPENDENCY_SCANNING_FILE,
......
...@@ -18,7 +18,8 @@ describe Ci::Pipeline do ...@@ -18,7 +18,8 @@ describe Ci::Pipeline do
end end
PIPELINE_ARTIFACTS_METHODS = [ PIPELINE_ARTIFACTS_METHODS = [
{ method: :codeclimate_artifact, options: [Ci::Build::CODEQUALITY_FILE, 'codequality'] }, { method: :codeclimate_artifact, options: [Ci::Build::CODECLIMATE_FILE, 'codequality'] },
{ method: :code_quality_artifact, options: [Ci::Build::CODEQUALITY_FILE, 'code_quality'] },
{ method: :performance_artifact, options: [Ci::Build::PERFORMANCE_FILE, 'performance'] }, { method: :performance_artifact, options: [Ci::Build::PERFORMANCE_FILE, 'performance'] },
{ method: :sast_artifact, options: [Ci::Build::SAST_FILE, 'sast'] }, { method: :sast_artifact, options: [Ci::Build::SAST_FILE, 'sast'] },
{ method: :dependency_scanning_artifact, options: [Ci::Build::DEPENDENCY_SCANNING_FILE, 'dependency_scanning'] }, { method: :dependency_scanning_artifact, options: [Ci::Build::DEPENDENCY_SCANNING_FILE, 'dependency_scanning'] },
...@@ -54,7 +55,7 @@ describe Ci::Pipeline do ...@@ -54,7 +55,7 @@ describe Ci::Pipeline do
it { expect(pipeline.send(method)).to eq(build) } it { expect(pipeline.send(method)).to eq(build) }
end end
context 'no code_quality job' do context 'no corresponding job' do
before do before do
create(:ci_build, pipeline: pipeline) create(:ci_build, pipeline: pipeline)
end end
...@@ -64,7 +65,7 @@ describe Ci::Pipeline do ...@@ -64,7 +65,7 @@ describe Ci::Pipeline do
end end
end end
%w(sast dast performance sast_container container_scanning).each do |type| %w(sast dependency_scanning dast performance sast_container container_scanning codeclimate code_quality).each do |type|
method = "has_#{type}_data?" method = "has_#{type}_data?"
describe "##{method}" do describe "##{method}" do
...@@ -78,7 +79,7 @@ describe Ci::Pipeline do ...@@ -78,7 +79,7 @@ describe Ci::Pipeline do
end end
end end
%w(sast dast performance sast_container container_scanning).each do |type| %w(sast dependency_scanning dast performance sast_container container_scanning codeclimate code_quality).each do |type|
method = "expose_#{type}_data?" method = "expose_#{type}_data?"
describe "##{method}" do describe "##{method}" do
......
...@@ -188,6 +188,23 @@ describe MergeRequest do ...@@ -188,6 +188,23 @@ describe MergeRequest do
end end
end end
describe '#expose_code_quality_data?' do
context 'with code_quality data' do
let(:pipeline) { double(expose_code_quality_data?: true) }
before do
allow(subject).to receive(:head_pipeline).and_return(pipeline)
allow(subject).to receive(:base_pipeline).and_return(pipeline)
end
it { expect(subject.expose_code_quality_data?).to be_truthy }
end
context 'without code_quality data' do
it { expect(subject.expose_code_quality_data?).to be_falsey }
end
end
describe '#expose_performance_data?' do describe '#expose_performance_data?' do
context 'with performance data' do context 'with performance data' do
let(:pipeline) { double(expose_performance_data?: true) } let(:pipeline) { double(expose_performance_data?: true) }
......
...@@ -26,6 +26,31 @@ describe MergeRequestWidgetEntity do ...@@ -26,6 +26,31 @@ describe MergeRequestWidgetEntity do
expect(subject.as_json[:blob_path]).to include(:head_path) expect(subject.as_json[:blob_path]).to include(:head_path)
end end
# methods for old artifact are deprecated and replaced with ones for the new name (#5779)
it 'has codeclimate data (with old artifact name codeclimate,json)' do
build = create(:ci_build, name: 'job')
allow(merge_request).to receive_messages(
expose_codeclimate_data?: true,
base_codeclimate_artifact: build,
head_codeclimate_artifact: build
)
expect(subject.as_json).to include(:codeclimate)
end
it 'has codeclimate data (with new artifact name gl-code-quality-report.json)' do
build = create(:ci_build, name: 'job')
allow(merge_request).to receive_messages(
expose_code_quality_data?: true,
base_code_quality_artifact: build,
head_code_quality_artifact: build
)
expect(subject.as_json).to include(:codeclimate)
end
it 'has performance data' do it 'has performance data' do
build = create(:ci_build, name: 'job') build = create(:ci_build, name: 'job')
......
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