23c1cfcc11
For each DetailedView subclass, we add a `warnings` array to: 1. The top-level response. 2. Each individual call under the `details` key. We use the `.thresholds` hash on the DetailedView to determine what's a warning. If that hash is empty (the default), then the warnings array will always be empty.
46 lines
1.1 KiB
Ruby
46 lines
1.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Peek
|
|
module Views
|
|
class Rugged < DetailedView
|
|
def results
|
|
return {} unless calls > 0
|
|
|
|
super
|
|
end
|
|
|
|
private
|
|
|
|
def duration
|
|
::Gitlab::RuggedInstrumentation.query_time_ms
|
|
end
|
|
|
|
def calls
|
|
::Gitlab::RuggedInstrumentation.query_count
|
|
end
|
|
|
|
def call_details
|
|
::Gitlab::RuggedInstrumentation.list_call_details
|
|
end
|
|
|
|
def format_call_details(call)
|
|
super.merge(args: format_args(call[:args]))
|
|
end
|
|
|
|
def format_args(args)
|
|
args.map do |arg|
|
|
# ActiveSupport::JSON recursively calls as_json on all
|
|
# instance variables, and if that instance variable points to
|
|
# something that refers back to the same instance, we can wind
|
|
# up in an infinite loop. Currently this only seems to happen with
|
|
# Gitlab::Git::Repository and ::Repository.
|
|
if arg.instance_variables.present?
|
|
arg.to_s
|
|
else
|
|
arg
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|