2018-11-20 20:47:30 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2019-07-07 11:18:12 +05:30
|
|
|
class MergeRequest::Metrics < ApplicationRecord
|
2023-04-23 21:23:45 +05:30
|
|
|
include IgnorableColumns
|
2023-07-09 08:55:56 +05:30
|
|
|
include DatabaseEventTracking
|
2023-04-23 21:23:45 +05:30
|
|
|
|
2020-10-24 23:57:45 +05:30
|
|
|
belongs_to :merge_request, inverse_of: :metrics
|
2017-08-17 22:00:37 +05:30
|
|
|
belongs_to :pipeline, class_name: 'Ci::Pipeline', foreign_key: :pipeline_id
|
2018-03-17 18:26:18 +05:30
|
|
|
belongs_to :latest_closed_by, class_name: 'User'
|
|
|
|
belongs_to :merged_by, class_name: 'User'
|
2021-03-11 19:13:27 +05:30
|
|
|
belongs_to :target_project, class_name: 'Project', inverse_of: :merge_requests
|
2020-10-24 23:57:45 +05:30
|
|
|
|
|
|
|
before_save :ensure_target_project_id
|
|
|
|
|
|
|
|
scope :merged_after, ->(date) { where(arel_table[:merged_at].gteq(date)) }
|
|
|
|
scope :merged_before, ->(date) { where(arel_table[:merged_at].lteq(date)) }
|
2021-02-22 17:27:13 +05:30
|
|
|
scope :with_valid_time_to_merge, -> { where(arel_table[:merged_at].gt(arel_table[:created_at])) }
|
2021-03-11 19:13:27 +05:30
|
|
|
scope :by_target_project, ->(project) { where(target_project_id: project) }
|
2021-02-22 17:27:13 +05:30
|
|
|
|
2023-04-23 21:23:45 +05:30
|
|
|
ignore_column :id_convert_to_bigint, remove_with: '16.0', remove_after: '2023-05-22'
|
|
|
|
|
2021-11-11 11:23:49 +05:30
|
|
|
class << self
|
|
|
|
def time_to_merge_expression
|
|
|
|
Arel.sql('EXTRACT(epoch FROM SUM(AGE(merge_request_metrics.merged_at, merge_request_metrics.created_at)))')
|
|
|
|
end
|
|
|
|
|
|
|
|
def record!(mr)
|
2023-07-09 08:55:56 +05:30
|
|
|
inserted_columns = %i[merge_request_id target_project_id updated_at created_at]
|
2021-11-11 11:23:49 +05:30
|
|
|
sql = <<~SQL
|
2023-07-09 08:55:56 +05:30
|
|
|
INSERT INTO #{self.table_name} (#{inserted_columns.join(', ')})
|
2021-11-11 11:23:49 +05:30
|
|
|
VALUES (#{mr.id}, #{mr.target_project_id}, NOW(), NOW())
|
|
|
|
ON CONFLICT (merge_request_id)
|
|
|
|
DO UPDATE SET
|
|
|
|
target_project_id = EXCLUDED.target_project_id,
|
|
|
|
updated_at = NOW()
|
2023-07-09 08:55:56 +05:30
|
|
|
RETURNING id, #{inserted_columns.join(', ')}
|
2021-11-11 11:23:49 +05:30
|
|
|
SQL
|
|
|
|
|
2023-07-09 08:55:56 +05:30
|
|
|
result = connection.execute(sql).first
|
|
|
|
new(result).publish_database_create_event
|
2021-11-11 11:23:49 +05:30
|
|
|
end
|
2021-02-22 17:27:13 +05:30
|
|
|
end
|
2020-10-24 23:57:45 +05:30
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def ensure_target_project_id
|
|
|
|
self.target_project_id ||= merge_request.target_project_id
|
|
|
|
end
|
2021-03-11 19:13:27 +05:30
|
|
|
|
|
|
|
def self.total_time_to_merge
|
|
|
|
with_valid_time_to_merge
|
2022-08-27 11:52:29 +05:30
|
|
|
.pick(time_to_merge_expression)
|
2021-03-11 19:13:27 +05:30
|
|
|
end
|
2023-07-09 08:55:56 +05:30
|
|
|
|
|
|
|
SNOWPLOW_ATTRIBUTES = %i[
|
|
|
|
id
|
|
|
|
merge_request_id
|
|
|
|
latest_build_started_at
|
|
|
|
latest_build_finished_at
|
|
|
|
first_deployed_to_production_at
|
|
|
|
merged_at
|
|
|
|
created_at
|
|
|
|
updated_at
|
|
|
|
pipeline_id
|
|
|
|
merged_by_id
|
|
|
|
latest_closed_by_id
|
|
|
|
latest_closed_at
|
|
|
|
first_comment_at
|
|
|
|
first_commit_at
|
|
|
|
last_commit_at
|
|
|
|
diff_size
|
|
|
|
modified_paths_size
|
|
|
|
commits_count
|
|
|
|
first_approved_at
|
|
|
|
first_reassigned_at
|
|
|
|
added_lines
|
|
|
|
removed_lines
|
|
|
|
].freeze
|
2016-09-29 09:46:39 +05:30
|
|
|
end
|
2020-04-08 14:13:33 +05:30
|
|
|
|
2021-06-08 01:23:25 +05:30
|
|
|
MergeRequest::Metrics.prepend_mod_with('MergeRequest::Metrics')
|