# frozen_string_literal: true module Gitlab module Analytics module CycleAnalytics class Median include StageQueryHelpers def initialize(stage:, query:, params: {}) @stage = stage @query = query @params = params end # rubocop: disable CodeReuse/ActiveRecord def seconds @query = @query.select(median_duration_in_seconds.as('median')).reorder(nil) result = execute_query(@query).first || {} result['median'] || nil end # rubocop: enable CodeReuse/ActiveRecord def days seconds ? seconds.fdiv(1.day) : nil end private attr_reader :stage, :params def percentile_cont percentile_cont_ordering = Arel::Nodes::UnaryOperation.new(Arel::Nodes::SqlLiteral.new('ORDER BY'), duration) Arel::Nodes::NamedFunction.new( 'percentile_cont(0.5) WITHIN GROUP', [percentile_cont_ordering] ) end def median_duration_in_seconds Arel::Nodes::NamedFunction.new('CAST', [Arel::Nodes::Extract.new(percentile_cont, :epoch).as('double precision')]) end end end end end