Sha256: 0aa80b1e3b8585916f79695986b833d355eb68a2cf47a01da440864816eb0a67

Contents?: true

Size: 1.76 KB

Versions: 77

Compression:

Stored size: 1.76 KB

Contents

module VCR
  # @private
  # Provides log message formatting helper methods.
  class Logger
    def initialize(stream)
      @stream = stream
    end

    def log(message, log_prefix, indentation_level = 0)
      indentation = '  ' * indentation_level
      log_message = indentation + log_prefix + message
      @stream.puts log_message
    end

    def request_summary(request, request_matchers)
      attributes = [request.method, request.uri]
      attributes << request.body.to_s[0, 80].inspect if request_matchers.include?(:body)
      attributes << request.headers.inspect          if request_matchers.include?(:headers)
      "[#{attributes.join(" ")}]"
    end

    def response_summary(response)
      "[#{response.status.code} #{response.body[0, 80].inspect}]"
    end

    # @private
    # A null-object version of the Logger. Used when
    # a `debug_logger` has not been set.
    #
    # @note We used to use a null object for the `debug_logger` itself,
    #       but some users noticed a negative perf impact from having the
    #       logger formatting logic still executing in that case, so we
    #       moved the null object interface up a layer to here.
    module Null
      module_function

      def log(*); end
      def request_summary(*); end
      def response_summary(*); end
    end

    # @private
    # Provides common logger helper methods that simply delegate to
    # the underlying logger object.
    module Mixin
      def log(message, indentation_level = 0)
        VCR.configuration.logger.log(message, log_prefix, indentation_level)
      end

      def request_summary(*args)
        VCR.configuration.logger.request_summary(*args)
      end

      def response_summary(*args)
        VCR.configuration.logger.response_summary(*args)
      end
    end
  end
end

Version data entries

77 entries across 77 versions & 11 rubygems

Version Path
docspring-3.0.0 vendor/bundle/ruby/3.3.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
cloudsmith-api-2.0.16 vendor/bundle/ruby/2.6.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
cloudsmith-api-2.0.15 vendor/bundle/ruby/2.6.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
cloudsmith-api-2.0.14 vendor/bundle/ruby/2.6.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
vcr-6.3.1 lib/vcr/util/logger.rb
vcr-6.3.0 lib/vcr/util/logger.rb
cloudsmith-api-2.0.13 vendor/bundle/ruby/2.6.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
cloudsmith-api-2.0.12 vendor/bundle/ruby/2.6.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
cloudsmith-api-2.0.11 vendor/bundle/ruby/2.6.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
cloudsmith-api-2.0.10 vendor/bundle/ruby/2.6.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
cloudsmith-api-2.0.9 vendor/bundle/ruby/2.6.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
cloudsmith-api-2.0.8 vendor/bundle/ruby/2.6.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
cloudsmith-api-2.0.7 vendor/bundle/ruby/2.6.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
vcr-6.2.0 lib/vcr/util/logger.rb
cloudsmith-api-2.0.6 vendor/bundle/ruby/2.6.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
cloudsmith-api-2.0.5 vendor/bundle/ruby/2.6.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
cloudsmith-api-2.0.4 vendor/bundle/ruby/2.6.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
cloudsmith-api-2.0.3 vendor/bundle/ruby/2.6.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
cloudsmith-api-2.0.2 vendor/bundle/ruby/2.6.0/gems/vcr-3.0.3/lib/vcr/util/logger.rb
fluent-plugin-google-cloud-logging-on-prem-0.1.0 vendor/ruby/3.1.0/gems/vcr-6.1.0/lib/vcr/util/logger.rb