Sha256: f847af969baf38d80a73ba64899c7ff7f6887e38d0965e653b2c45df5ed059a9

Contents?: true

Size: 1.06 KB

Versions: 7

Compression:

Stored size: 1.06 KB

Contents

# frozen_string_literal: true

require 'deimos/metrics/provider'

module Deimos
  module Metrics
    # A mock Metrics wrapper which just logs the metrics
    class Mock
      # :nodoc:
      def initialize(logger=nil)
        @logger = logger || Logger.new(STDOUT)
        @logger.info('MockMetricsProvider initialized')
      end

      # :nodoc:
      def increment(metric_name, options)
        @logger.info("MockMetricsProvider.increment: #{metric_name}, #{options}")
      end

      # :nodoc:
      def gauge(metric_name, count, options)
        @logger.info("MockMetricsProvider.gauge: #{metric_name}, #{count}, #{options}")
      end

      # :nodoc:
      def histogram(metric_name, count, options)
        @logger.info("MockMetricsProvider.histogram: #{metric_name}, #{count}, #{options}")
      end

      # :nodoc:
      def time(metric_name, options={})
        start_time = Time.now
        yield
        total_time = (Time.now - start_time).to_i
        @logger.info("MockMetricsProvider.time: #{metric_name}, #{total_time}, #{options}")
      end
    end
  end
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
deimos-kafka-1.0.0.pre.beta21 lib/deimos/metrics/mock.rb
deimos-kafka-1.0.0.pre.beta20 lib/deimos/metrics/mock.rb
deimos-kafka-1.0.0.pre.beta19 lib/deimos/metrics/mock.rb
deimos-kafka-1.0.0.pre.beta18 lib/deimos/metrics/mock.rb
deimos-kafka-1.0.0.pre.beta17 lib/deimos/metrics/mock.rb
deimos-kafka-1.0.0.pre.beta16 lib/deimos/metrics/mock.rb
deimos-kafka-1.0.0.pre.beta15 lib/deimos/metrics/mock.rb