Commit cc9bf431 authored by Maxime Orefice's avatar Maxime Orefice

Refactor pipeline artifacts logic

This MR refactors our logic determining if a pipeline can generate
a coverage report and if a given pipeline has a coverage report
attached to it.
parent 7f6fc1bc
...@@ -865,7 +865,11 @@ module Ci ...@@ -865,7 +865,11 @@ module Ci
end end
def has_coverage_reports? def has_coverage_reports?
self.has_reports?(Ci::JobArtifact.coverage_reports) pipeline_artifacts&.has_code_coverage?
end
def can_generate_coverage_reports?
has_reports?(Ci::JobArtifact.coverage_reports)
end end
def test_report_summary def test_report_summary
......
...@@ -1346,7 +1346,7 @@ class MergeRequest < ApplicationRecord ...@@ -1346,7 +1346,7 @@ class MergeRequest < ApplicationRecord
def has_coverage_reports? def has_coverage_reports?
return false unless Feature.enabled?(:coverage_report_view, project) return false unless Feature.enabled?(:coverage_report_view, project)
actual_head_pipeline&.pipeline_artifacts&.has_code_coverage? actual_head_pipeline&.has_coverage_reports?
end end
def has_terraform_reports? def has_terraform_reports?
......
...@@ -4,8 +4,8 @@ module Ci ...@@ -4,8 +4,8 @@ module Ci
class CreateArtifactService class CreateArtifactService
def execute(pipeline) def execute(pipeline)
return unless ::Gitlab::Ci::Features.coverage_report_view?(pipeline.project) return unless ::Gitlab::Ci::Features.coverage_report_view?(pipeline.project)
return unless pipeline.has_coverage_reports? return unless pipeline.can_generate_coverage_reports?
return if pipeline.pipeline_artifacts.has_code_coverage? return if pipeline.has_coverage_reports?
file = build_carrierwave_file(pipeline) file = build_carrierwave_file(pipeline)
......
...@@ -2944,6 +2944,22 @@ RSpec.describe Ci::Pipeline, :mailer, factory_default: :keep do ...@@ -2944,6 +2944,22 @@ RSpec.describe Ci::Pipeline, :mailer, factory_default: :keep do
describe '#has_coverage_reports?' do describe '#has_coverage_reports?' do
subject { pipeline.has_coverage_reports? } subject { pipeline.has_coverage_reports? }
context 'when pipeline has a code coverage artifact' do
let(:pipeline) { create(:ci_pipeline, :with_coverage_report_artifact, :running, project: project) }
it { expect(subject).to be_truthy }
end
context 'when pipeline does not have a code coverage artifact' do
let(:pipeline) { create(:ci_pipeline, :success, project: project) }
it { expect(subject).to be_falsey }
end
end
describe '#can_generate_coverage_reports?' do
subject { pipeline.can_generate_coverage_reports? }
context 'when pipeline has builds with coverage reports' do context 'when pipeline has builds with coverage reports' do
before do before do
create(:ci_build, :coverage_reports, pipeline: pipeline, project: project) create(:ci_build, :coverage_reports, pipeline: pipeline, project: project)
......
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