Sha256: a3b18f528d198a598e9d6f9c00fad892be895f6fca4f343152465b2a0d357d23
Contents?: true
Size: 1.79 KB
Versions: 3
Compression:
Stored size: 1.79 KB
Contents
module StatsD::Instrument::Assertions def capture_statsd_calls(&block) mock_backend = StatsD::Instrument::Backends::CaptureBackend.new old_backend, StatsD.backend = StatsD.backend, mock_backend block.call mock_backend.collected_metrics ensure StatsD.backend = old_backend end def assert_no_statsd_calls(metric_name = nil, &block) metrics = capture_statsd_calls(&block) metrics.select! { |m| m.name == metric_name } if metric_name assert metrics.empty?, "No StatsD calls for metric #{metric_name} expected." end def assert_statsd_increment(metric_name, options = {}, &block) assert_statsd_call(:c, metric_name, options, &block) end def assert_statsd_measure(metric_name, options = {}, &block) assert_statsd_call(:ms, metric_name, options, &block) end def assert_statsd_gauge(metric_name, options = {}, &block) assert_statsd_call(:g, metric_name, options, &block) end private def assert_statsd_call(metric_type, metric_name, options = {}, &block) options[:times] ||= 1 metrics = capture_statsd_calls(&block) metrics = metrics.select { |m| m.type == metric_type && m.name == metric_name } assert metrics.length > 0, "No StatsD calls for metric #{metric_name} were made." assert options[:times] === metrics.length, "The amount of StatsD calls for metric #{metric_name} was unexpected" metric = metrics.first assert_equal options[:sample_rate], metric.sample_rate, "Unexpected value submitted for StatsD metric #{metric_name}" if options[:sample_rate] assert_equal options[:value], metric.value, "Unexpected StatsD sample rate for metric #{metric_name}" if options[:value] assert_equal Set.new(options[:tags]), Set.new(metric.tags), "Unexpected StatsD tags for metric #{metric_name}" if options[:tags] metric end end
Version data entries
3 entries across 3 versions & 1 rubygems