summaryrefslogtreecommitdiff
path: root/app/models/ci/daily_build_group_report_result.rb
blob: 23c96e63724fa566ab67a8ae9894965e7214eea0 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# 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
    belongs_to :group

    validates :data, json_schema: { filename: "daily_build_group_report_result_data" }

    scope :with_included_projects, -> { includes(:project) }
    scope :by_ref_path, -> (ref_path) { where(ref_path: ref_path) }
    scope :by_projects, -> (ids) { where(project_id: ids) }
    scope :by_group, -> (group_id) { where(group_id: group_id) }
    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) }
    scope :by_dates, -> (start_date, end_date) { where(date: start_date..end_date) }
    scope :ordered_by_date_and_group_name, -> { order(date: :desc, group_name: :asc) }

    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')