2017-09-10 17:25:29 +05:30
|
|
|
module SystemCheck
|
|
|
|
# Simple Executor is current default executor for GitLab
|
|
|
|
# It is a simple port from display logic in the old check.rake
|
|
|
|
#
|
|
|
|
# There is no concurrency level and the output is progressively
|
|
|
|
# printed into the STDOUT
|
|
|
|
#
|
|
|
|
# @attr_reader [Array<BaseCheck>] checks classes of corresponding checks to be executed in the same order
|
|
|
|
# @attr_reader [String] component name of the component relative to the checks being executed
|
|
|
|
class SimpleExecutor
|
|
|
|
attr_reader :checks
|
|
|
|
attr_reader :component
|
|
|
|
|
|
|
|
# @param [String] component name of the component relative to the checks being executed
|
|
|
|
def initialize(component)
|
|
|
|
raise ArgumentError unless component.is_a? String
|
|
|
|
|
|
|
|
@component = component
|
|
|
|
@checks = Set.new
|
|
|
|
end
|
|
|
|
|
|
|
|
# Add a check to be executed
|
|
|
|
#
|
|
|
|
# @param [BaseCheck] check class
|
|
|
|
def <<(check)
|
2018-03-17 18:26:18 +05:30
|
|
|
raise ArgumentError unless check.is_a?(Class) && check < BaseCheck
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
@checks << check
|
|
|
|
end
|
|
|
|
|
|
|
|
# Executes defined checks in the specified order and outputs confirmation or error information
|
|
|
|
def execute
|
|
|
|
start_checking(component)
|
|
|
|
|
|
|
|
@checks.each do |check|
|
|
|
|
run_check(check)
|
|
|
|
end
|
|
|
|
|
|
|
|
finished_checking(component)
|
|
|
|
end
|
|
|
|
|
|
|
|
# Executes a single check
|
|
|
|
#
|
|
|
|
# @param [SystemCheck::BaseCheck] check_klass
|
|
|
|
def run_check(check_klass)
|
2018-11-08 19:23:39 +05:30
|
|
|
print_display_name(check_klass)
|
2017-09-10 17:25:29 +05:30
|
|
|
|
|
|
|
check = check_klass.new
|
|
|
|
|
|
|
|
# When implements skip method, we run it first, and if true, skip the check
|
|
|
|
if check.can_skip? && check.skip?
|
2018-03-17 18:26:18 +05:30
|
|
|
$stdout.puts check.skip_reason.try(:color, :magenta) || check_klass.skip_reason.color(:magenta)
|
2017-09-10 17:25:29 +05:30
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
# When implements a multi check, we don't control the output
|
2018-03-17 18:26:18 +05:30
|
|
|
if check.multi_check?
|
2017-09-10 17:25:29 +05:30
|
|
|
check.multi_check
|
|
|
|
return
|
|
|
|
end
|
|
|
|
|
|
|
|
if check.check?
|
2018-11-08 19:23:39 +05:30
|
|
|
print_check_pass(check_klass)
|
2017-09-10 17:25:29 +05:30
|
|
|
else
|
2018-11-08 19:23:39 +05:30
|
|
|
print_check_failure(check_klass)
|
2017-09-10 17:25:29 +05:30
|
|
|
|
|
|
|
if check.can_repair?
|
|
|
|
$stdout.print 'Trying to fix error automatically. ...'
|
2018-03-17 18:26:18 +05:30
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
if check.repair!
|
2018-11-08 19:23:39 +05:30
|
|
|
print_success
|
2017-09-10 17:25:29 +05:30
|
|
|
return
|
|
|
|
else
|
2018-11-08 19:23:39 +05:30
|
|
|
print_failure
|
2017-09-10 17:25:29 +05:30
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
check.show_error
|
|
|
|
end
|
|
|
|
rescue StandardError => e
|
|
|
|
$stdout.puts "Exception: #{e.message}".color(:red)
|
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
2018-11-08 19:23:39 +05:30
|
|
|
def print_display_name(check_klass)
|
|
|
|
$stdout.print "#{check_klass.display_name} ... "
|
|
|
|
end
|
|
|
|
|
|
|
|
def print_check_pass(check_klass)
|
|
|
|
$stdout.puts check_klass.check_pass.color(:green)
|
|
|
|
end
|
|
|
|
|
|
|
|
def print_check_failure(check_klass)
|
|
|
|
$stdout.puts check_klass.check_fail.color(:red)
|
|
|
|
end
|
|
|
|
|
|
|
|
def print_success
|
|
|
|
$stdout.puts 'Success'.color(:green)
|
|
|
|
end
|
|
|
|
|
|
|
|
def print_failure
|
|
|
|
$stdout.puts 'Failed'.color(:red)
|
|
|
|
end
|
|
|
|
|
2017-09-10 17:25:29 +05:30
|
|
|
# Prints header content for the series of checks to be executed for this component
|
|
|
|
#
|
|
|
|
# @param [String] component name of the component relative to the checks being executed
|
|
|
|
def start_checking(component)
|
|
|
|
$stdout.puts "Checking #{component.color(:yellow)} ..."
|
|
|
|
$stdout.puts ''
|
|
|
|
end
|
|
|
|
|
|
|
|
# Prints footer content for the series of checks executed for this component
|
|
|
|
#
|
|
|
|
# @param [String] component name of the component relative to the checks being executed
|
|
|
|
def finished_checking(component)
|
|
|
|
$stdout.puts ''
|
|
|
|
$stdout.puts "Checking #{component.color(:yellow)} ... #{'Finished'.color(:green)}"
|
|
|
|
$stdout.puts ''
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|