Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'lib/gitlab/analytics/cycle_analytics/stage_query_helpers.rb')
-rw-r--r--lib/gitlab/analytics/cycle_analytics/stage_query_helpers.rb26
1 files changed, 19 insertions, 7 deletions
diff --git a/lib/gitlab/analytics/cycle_analytics/stage_query_helpers.rb b/lib/gitlab/analytics/cycle_analytics/stage_query_helpers.rb
index 777a8278e6e..11fe1dde12f 100644
--- a/lib/gitlab/analytics/cycle_analytics/stage_query_helpers.rb
+++ b/lib/gitlab/analytics/cycle_analytics/stage_query_helpers.rb
@@ -18,22 +18,30 @@ module Gitlab
def duration
Arel::Nodes::Subtraction.new(
- stage.end_event.timestamp_projection,
+ end_event_timestamp_projection,
stage.start_event.timestamp_projection
)
end
+ def end_event_timestamp_projection
+ if in_progress?
+ Arel::Nodes::NamedFunction.new('TO_TIMESTAMP', [Time.current.to_i])
+ else
+ stage.end_event.timestamp_projection
+ end
+ end
+
# rubocop: disable CodeReuse/ActiveRecord
def order_by(query, sort, direction, extra_columns_to_select = [:id])
- ordered_query = Gitlab::Analytics::CycleAnalytics::Sorting.apply(query, stage, sort, direction)
+ ordered_query = Gitlab::Analytics::CycleAnalytics::Sorting.new(stage: stage, query: query, params: params).apply(sort, direction)
# When filtering for more than one label, postgres requires the columns in ORDER BY to be present in the GROUP BY clause
if requires_grouping?
- column_list = [
- *extra_columns_to_select,
- *stage.end_event.column_list,
- *stage.start_event.column_list
- ]
+ column_list = [].tap do |array|
+ array.concat(extra_columns_to_select)
+ array.concat(stage.end_event.column_list) unless in_progress?
+ array.concat(stage.start_event.column_list)
+ end
ordered_query = ordered_query.group(column_list)
end
@@ -45,6 +53,10 @@ module Gitlab
def requires_grouping?
Array(params[:label_name]).size > 1
end
+
+ def in_progress?
+ params[:end_event_filter] == :in_progress
+ end
end
end
end