2018-11-05 23:45:35 -05:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2016-12-09 06:41:15 -05:00
|
|
|
module Gitlab
|
|
|
|
module CycleAnalytics
|
|
|
|
module BaseQuery
|
|
|
|
include MetricsTables
|
|
|
|
include Gitlab::Database::Median
|
|
|
|
include Gitlab::Database::DateTime
|
|
|
|
|
|
|
|
private
|
|
|
|
|
2018-02-13 10:42:49 -05:00
|
|
|
def base_query
|
2019-07-04 09:04:30 -04:00
|
|
|
@base_query ||= stage_query(projects.map(&:id))
|
2016-12-09 06:41:15 -05:00
|
|
|
end
|
|
|
|
|
2018-02-13 10:42:49 -05:00
|
|
|
def stage_query(project_ids)
|
2017-06-21 09:48:12 -04:00
|
|
|
query = mr_closing_issues_table.join(issue_table).on(issue_table[:id].eq(mr_closing_issues_table[:issue_id]))
|
|
|
|
.join(issue_metrics_table).on(issue_table[:id].eq(issue_metrics_table[:issue_id]))
|
2019-07-04 10:42:31 -04:00
|
|
|
.join(projects_table).on(issue_table[:project_id].eq(projects_table[:id]))
|
|
|
|
.join(routes_table).on(projects_table[:namespace_id].eq(routes_table[:source_id]))
|
2018-02-13 10:42:49 -05:00
|
|
|
.project(issue_table[:project_id].as("project_id"))
|
2018-02-21 07:13:56 -05:00
|
|
|
.where(issue_table[:project_id].in(project_ids))
|
2019-07-04 10:42:31 -04:00
|
|
|
.where(routes_table[:source_type].eq('Namespace'))
|
2019-07-10 07:22:29 -04:00
|
|
|
.where(issue_table[:created_at].gteq(options[:from]))
|
2016-12-09 06:41:15 -05:00
|
|
|
|
|
|
|
# Load merge_requests
|
2019-07-04 10:42:31 -04:00
|
|
|
|
|
|
|
query = load_merge_requests(query)
|
|
|
|
|
|
|
|
query
|
|
|
|
end
|
|
|
|
|
|
|
|
def load_merge_requests(query)
|
|
|
|
query.join(mr_table, Arel::Nodes::OuterJoin)
|
2017-06-21 09:48:12 -04:00
|
|
|
.on(mr_table[:id].eq(mr_closing_issues_table[:merge_request_id]))
|
|
|
|
.join(mr_metrics_table)
|
|
|
|
.on(mr_table[:id].eq(mr_metrics_table[:merge_request_id]))
|
2016-12-09 06:41:15 -05:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|