Module: Gitlab::CycleAnalytics::PlanHelper

Included in:
PlanEventFetcher, PlanStage
Defined in:
lib/gitlab/cycle_analytics/plan_helper.rb

Instance Method Summary collapse

Instance Method Details

#limit_query(query) ⇒ Object


20
21
22
23
# File 'lib/gitlab/cycle_analytics/plan_helper.rb', line 20

def limit_query(query)
  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)))
    .where(issue_metrics_table[:first_mentioned_in_commit_at].not_eq(nil))
end

#stage_query(project_ids) ⇒ Object


6
7
8
9
10
11
12
13
14
15
16
17
18
# File 'lib/gitlab/cycle_analytics/plan_helper.rb', line 6

def stage_query(project_ids)
  query = issue_table.join(issue_metrics_table).on(issue_table[:id].eq(issue_metrics_table[:issue_id]))
    .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]))
    .project(issue_table[:project_id].as("project_id"))
    .project(projects_table[:path].as("project_path"))
    .project(routes_table[:path].as("namespace_path"))
    .where(issue_table[:project_id].in(project_ids))
    .where(routes_table[:source_type].eq('Namespace'))
  query = limit_query(query)

  limit_query_by_date_range(query)
end