Sha256: c710a6e214262e2005c5e5c597f00a5f1f12b24b75ba40b83811d6d5e4d60ebe
Contents?: true
Size: 1.47 KB
Versions: 10
Compression:
Stored size: 1.47 KB
Contents
# frozen_string_literal: true require 'bolt/pal' module Bolt class Outputter class Logger < Bolt::Outputter def initialize(verbose, trace) super(false, verbose, trace, false) @logger = Bolt::Logger.logger(self) end def handle_event(event) case event[:type] when :step_start log_step_start(**event) when :step_finish log_step_finish(**event) when :plan_start log_plan_start(event) when :plan_finish log_plan_finish(event) end end def log_step_start(description:, targets:, **_kwargs) target_str = if targets.length > 5 "#{targets.count} targets" else targets.map(&:safe_name).join(', ') end @logger.info("Starting: #{description} on #{target_str}") end def log_step_finish(description:, result:, duration:, **_kwargs) failures = result.error_set.length plural = failures == 1 ? '' : 's' @logger.info("Finished: #{description} with #{failures} failure#{plural} in #{duration.round(2)} sec") end def log_plan_start(event) plan = event[:plan] @logger.info("Starting: plan #{plan}") end def log_plan_finish(event) plan = event[:plan] duration = event[:duration] @logger.info("Finished: plan #{plan} in #{duration.round(2)} sec") end end end end
Version data entries
10 entries across 10 versions & 1 rubygems