2019-06-17 09:17:18 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Gitlab
|
|
|
|
module CycleAnalytics
|
|
|
|
module PlanHelper
|
|
|
|
def stage_query(project_ids)
|
|
|
|
query = issue_table.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]))
|
2019-06-17 09:17:18 -04:00
|
|
|
.project(issue_table[:project_id].as("project_id"))
|
2019-08-05 17:15:00 -04:00
|
|
|
.project(projects_table[:path].as("project_path"))
|
|
|
|
.project(routes_table[:path].as("namespace_path"))
|
2019-06-17 09:17:18 -04: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-08-05 17:15:00 -04:00
|
|
|
query = limit_query(query)
|
2019-06-17 09:17:18 -04:00
|
|
|
|
2019-10-07 17:07:54 -04:00
|
|
|
limit_query_by_date_range(query)
|
2019-06-17 09:17:18 -04:00
|
|
|
end
|
2019-07-04 10:42:31 -04:00
|
|
|
|
2019-08-05 17:15:00 -04:00
|
|
|
def limit_query(query)
|
2019-10-07 17:07:54 -04:00
|
|
|
query.where(issue_metrics_table[:first_added_to_board_at].not_eq(nil).or(issue_metrics_table[:first_associated_with_milestone_at].not_eq(nil)))
|
2019-07-04 10:42:31 -04:00
|
|
|
.where(issue_metrics_table[:first_mentioned_in_commit_at].not_eq(nil))
|
|
|
|
end
|
2019-06-17 09:17:18 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|