Sha256: 6645d6294d106787e256d723faf1bc68b0ca15a2789733af36b54c81b6b61524
Contents?: true
Size: 1.45 KB
Versions: 3
Compression:
Stored size: 1.45 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) @logger = Logging.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
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
bolt-2.25.0 | lib/bolt/outputter/logger.rb |
bolt-2.24.1 | lib/bolt/outputter/logger.rb |
bolt-2.24.0 | lib/bolt/outputter/logger.rb |