gitlab-org--gitlab-foss/lib/peek/views/rugged.rb
Sean McGivern 23c1cfcc11 Return warnings for performance bar from backend
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.
2019-08-28 16:39:33 +01:00

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