43 lines
1.3 KiB
Ruby
43 lines
1.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Ci
|
|
class DailyBuildGroupReportResult < ApplicationRecord
|
|
extend Gitlab::Ci::Model
|
|
|
|
REPORT_WINDOW = 90.days
|
|
PARAM_TYPES = %w[coverage].freeze
|
|
|
|
belongs_to :last_pipeline, class_name: 'Ci::Pipeline', foreign_key: :last_pipeline_id
|
|
belongs_to :project
|
|
|
|
validates :data, json_schema: { filename: "daily_build_group_report_result_data" }
|
|
|
|
scope :with_included_projects, -> { includes(:project) }
|
|
scope :by_projects, -> (ids) { where(project_id: ids) }
|
|
scope :with_coverage, -> { where("(data->'coverage') IS NOT NULL") }
|
|
scope :with_default_branch, -> { where(default_branch: true) }
|
|
scope :by_date, -> (start_date) { where(date: report_window(start_date)..Date.current) }
|
|
|
|
store_accessor :data, :coverage
|
|
|
|
class << self
|
|
def upsert_reports(data)
|
|
upsert_all(data, unique_by: :index_daily_build_group_report_results_unique_columns) if data.any?
|
|
end
|
|
|
|
def recent_results(attrs, limit: nil)
|
|
where(attrs).order(date: :desc, group_name: :asc).limit(limit)
|
|
end
|
|
|
|
def report_window(start_date)
|
|
default_date = REPORT_WINDOW.ago.to_date
|
|
date = Date.parse(start_date) rescue default_date
|
|
|
|
[date, default_date].max
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
Ci::DailyBuildGroupReportResult.prepend_if_ee('EE::Ci::DailyBuildGroupReportResult')
|