Commit 7ed0806a authored by nmilojevic1's avatar nmilojevic1

Add cached queries to the performance bar

parent 2aaa1509
......@@ -36,7 +36,7 @@ export default {
metric: 'active-record',
title: 'pg',
header: s__('PerformanceBar|SQL queries'),
keys: ['sql'],
keys: ['sql', 'cached'],
},
{
metric: 'bullet',
......
......@@ -5,6 +5,7 @@ module Peek
class ActiveRecord < DetailedView
DEFAULT_THRESHOLDS = {
calls: 100,
cached_calls: 100,
duration: 3000,
individual_call: 1000
}.freeze
......@@ -12,32 +13,56 @@ module Peek
THRESHOLDS = {
production: {
calls: 100,
cached_calls: 100,
duration: 15000,
individual_call: 5000
}
}.freeze
def results
super.merge(calls: detailed_calls)
end
def self.thresholds
@thresholds ||= THRESHOLDS.fetch(Rails.env.to_sym, DEFAULT_THRESHOLDS)
end
private
def detailed_calls
cached_calls? ? "#{calls} | #{cached_calls}" : calls
end
def calls
super - cached_calls
end
def cached_calls
detail_store.count { |item| item[:cached] == 'cached' }
end
def cached_calls?
detail_store.any? { |item| item[:cached] == 'cached' }
end
def warnings
(super + warning_for(cached_calls, self.class.thresholds[:cached_calls], label: "#{key} cached calls")).compact
end
def setup_subscribers
super
subscribe('sql.active_record') do |_, start, finish, _, data|
if Gitlab::PerformanceBar.enabled_for_request?
unless data[:cached]
detail_store << {
duration: finish - start,
sql: data[:sql].strip,
backtrace: Gitlab::BacktraceCleaner.clean_backtrace(caller)
backtrace: Gitlab::BacktraceCleaner.clean_backtrace(caller),
cached: data[:cached] ? 'cached' : ''
}
end
end
end
end
end
end
end
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment