2019-07-17 19:34:27 -04:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Gitlab
|
|
|
|
module RuggedInstrumentation
|
|
|
|
def self.query_time
|
2020-05-20 20:08:06 -04:00
|
|
|
query_time = SafeRequestStore[:rugged_query_time] || 0
|
2020-04-27 23:09:53 -04:00
|
|
|
query_time.round(Gitlab::InstrumentationHelper::DURATION_PRECISION)
|
2019-07-17 19:34:27 -04:00
|
|
|
end
|
|
|
|
|
2020-05-20 20:08:06 -04:00
|
|
|
def self.add_query_time(duration)
|
|
|
|
SafeRequestStore[:rugged_query_time] ||= 0
|
|
|
|
SafeRequestStore[:rugged_query_time] += duration
|
2019-07-17 19:34:27 -04:00
|
|
|
end
|
|
|
|
|
|
|
|
def self.query_time_ms
|
|
|
|
(self.query_time * 1000).round(2)
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.query_count
|
|
|
|
SafeRequestStore[:rugged_call_count] ||= 0
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.increment_query_count
|
|
|
|
SafeRequestStore[:rugged_call_count] ||= 0
|
|
|
|
SafeRequestStore[:rugged_call_count] += 1
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.active?
|
2019-07-21 01:34:46 -04:00
|
|
|
SafeRequestStore.active?
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.add_call_details(details)
|
2019-08-27 07:40:44 -04:00
|
|
|
return unless Gitlab::PerformanceBar.enabled_for_request?
|
2019-07-21 01:34:46 -04:00
|
|
|
|
|
|
|
Gitlab::SafeRequestStore[:rugged_call_details] ||= []
|
|
|
|
Gitlab::SafeRequestStore[:rugged_call_details] << details
|
|
|
|
end
|
|
|
|
|
|
|
|
def self.list_call_details
|
2019-08-27 07:40:44 -04:00
|
|
|
return [] unless Gitlab::PerformanceBar.enabled_for_request?
|
2019-07-21 01:34:46 -04:00
|
|
|
|
|
|
|
Gitlab::SafeRequestStore[:rugged_call_details] || []
|
2019-07-17 19:34:27 -04:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|