47 lines
1.2 KiB
Ruby
47 lines
1.2 KiB
Ruby
# 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
|