newcontext-oss/kitchen-terraform

View on GitHub
lib/kitchen/terraform/debug_logger.rb

Summary

Maintainability
A
0 mins
Test Coverage
A
100%
# frozen_string_literal: true

# Copyright 2016-2021 Copado NCS LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

require "delegate"

module Kitchen
  module Terraform
    # This class delegates to a logger but ensures the debug level is the default level used for logging messages.
    class DebugLogger < ::SimpleDelegator
      class << self
        # .new creates a new instance of the class.
        #
        # @return [Kitchen::Terraform::DebugLogger]
        def new(obj)
          if !obj.kind_of? ::Kitchen::Logger
            raise ::TypeError, "delegate must be a Kitchen::Logger; recevied #{obj.class}"
          end

          super
        end
      end

      # This method overrides the #<< method of the delegate to call #debug.
      #
      # @param message [#to_s] the message to be logged.
      # @return [nil, true] if the given severity is high enough for this particular logger then return
      #   <code>nil</code>; else return <code>true</code>.
      def <<(message)
        debug message
      end
    end
  end
end