debian-mirror-gitlab/lib/gitlab/cycle_analytics/plan_helper.rb

28 lines
1.1 KiB
Ruby
Raw Normal View History

2019-09-04 21:01:54 +05:30
# 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-10-12 21:52:04 +05:30
.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-09-04 21:01:54 +05:30
.project(issue_table[:project_id].as("project_id"))
2019-10-12 21:52:04 +05:30
.project(projects_table[:path].as("project_path"))
.project(routes_table[:path].as("namespace_path"))
2019-09-04 21:01:54 +05:30
.where(issue_table[:project_id].in(project_ids))
2019-10-12 21:52:04 +05:30
.where(routes_table[:source_type].eq('Namespace'))
query = limit_query(query)
2019-09-04 21:01:54 +05:30
query
end
2019-10-12 21:52:04 +05:30
def limit_query(query)
query.where(issue_table[:created_at].gteq(options[:from]))
.where(issue_metrics_table[:first_added_to_board_at].not_eq(nil).or(issue_metrics_table[:first_associated_with_milestone_at].not_eq(nil)))
.where(issue_metrics_table[:first_mentioned_in_commit_at].not_eq(nil))
end
2019-09-04 21:01:54 +05:30
end
end
end