Class: Ci::GenerateCoverageReportsService
- Inherits:
-
CompareReportsBaseService
- Object
- BaseService
- CompareReportsBaseService
- Ci::GenerateCoverageReportsService
- Defined in:
- app/services/ci/generate_coverage_reports_service.rb
Overview
TODO: a couple of points with this approach: + reuses existing architecture and reactive caching
-
it’s not a report comparison and some comparing features must be turned off.
see CompareReportsBaseService for more notes. issue: gitlab.com/gitlab-org/gitlab/issues/34224
Instance Attribute Summary
Attributes inherited from BaseService
#current_user, #params, #project
Instance Method Summary collapse
- #execute(base_pipeline, head_pipeline) ⇒ Object
- #latest?(base_pipeline, head_pipeline, data) ⇒ Boolean
Methods inherited from BaseService
Methods included from BaseServiceUtility
#deny_visibility_level, #event_service, #log_error, #log_info, #notification_service, #system_hook_service, #todo_service, #visibility_level
Methods included from Gitlab::Allowable
Constructor Details
This class inherits a constructor from BaseService
Instance Method Details
#execute(base_pipeline, head_pipeline) ⇒ Object
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 |
# File 'app/services/ci/generate_coverage_reports_service.rb', line 10 def execute(base_pipeline, head_pipeline) merge_request = MergeRequest.find_by_id(params[:id]) { status: :parsed, key: key(base_pipeline, head_pipeline), data: head_pipeline.pipeline_artifacts.find_by_file_type(:code_coverage).present.for_files(merge_request.new_paths) } rescue StandardError => e Gitlab::ErrorTracking.track_exception( e, project_id: project.id, base_pipeline_id: base_pipeline&.id, head_pipeline_id: head_pipeline&.id ) { status: :error, key: key(base_pipeline, head_pipeline), status_reason: _('An error occurred while fetching coverage reports.') } end |
#latest?(base_pipeline, head_pipeline, data) ⇒ Boolean
32 33 34 |
# File 'app/services/ci/generate_coverage_reports_service.rb', line 32 def latest?(base_pipeline, head_pipeline, data) data&.fetch(:key, nil) == key(base_pipeline, head_pipeline) end |