2018-12-23 12:14:25 +05:30
|
|
|
# frozen_string_literal: true
|
|
|
|
|
2017-08-17 22:00:37 +05:30
|
|
|
module Gitlab
|
|
|
|
module HealthChecks
|
|
|
|
module SimpleAbstractCheck
|
|
|
|
include BaseAbstractCheck
|
|
|
|
|
|
|
|
def readiness
|
|
|
|
check_result = check
|
2018-03-17 18:26:18 +05:30
|
|
|
if successful?(check_result)
|
2017-08-17 22:00:37 +05:30
|
|
|
HealthChecks::Result.new(true)
|
|
|
|
elsif check_result.is_a?(Timeout::Error)
|
|
|
|
HealthChecks::Result.new(false, "#{human_name} check timed out")
|
|
|
|
else
|
|
|
|
HealthChecks::Result.new(false, "unexpected #{human_name} check result: #{check_result}")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def metrics
|
2017-09-10 17:25:29 +05:30
|
|
|
result, elapsed = with_timing(&method(:check))
|
2018-03-17 18:26:18 +05:30
|
|
|
Rails.logger.error("#{human_name} check returned unexpected result #{result}") unless successful?(result)
|
2017-09-10 17:25:29 +05:30
|
|
|
[
|
|
|
|
metric("#{metric_prefix}_timeout", result.is_a?(Timeout::Error) ? 1 : 0),
|
2018-03-17 18:26:18 +05:30
|
|
|
metric("#{metric_prefix}_success", successful?(result) ? 1 : 0),
|
2017-09-10 17:25:29 +05:30
|
|
|
metric("#{metric_prefix}_latency_seconds", elapsed)
|
|
|
|
]
|
2017-08-17 22:00:37 +05:30
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def metric_prefix
|
|
|
|
raise NotImplementedError
|
|
|
|
end
|
|
|
|
|
2018-03-17 18:26:18 +05:30
|
|
|
def successful?(result)
|
2017-08-17 22:00:37 +05:30
|
|
|
raise NotImplementedError
|
|
|
|
end
|
|
|
|
|
|
|
|
def check
|
|
|
|
raise NotImplementedError
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|