Sha256: c7eaccbbc9d62be3e4a7c072dd0236c850e8d3ea5ebaacbfde5dc280d26f8e82
Contents?: true
Size: 1.05 KB
Versions: 1
Compression:
Stored size: 1.05 KB
Contents
# encoding: utf-8 require "logstash/instrument/namespaced_metric" require "logstash/instrument/metric" require_relative "../../support/matchers" require "spec_helper" describe LogStash::Instrument::NamespacedMetric do let(:namespace) { :stats } let(:collector) { [] } let(:metric) { LogStash::Instrument::Metric.new(collector) } subject { described_class.new(metric, namespace) } it "defines the same interface as `Metric`" do expect(described_class).to implement_interface_of(LogStash::Instrument::Metric) end it "returns a TimedException when we call without a block" do expect(subject.time(:duration_ms)).to be_kind_of(LogStash::Instrument::Metric::TimedExecution) end it "returns the value of the block" do expect(subject.time(:duration_ms) { "hello" }).to eq("hello") end it "its doesnt change the original `namespace` when creating a subnamespace" do new_namespace = subject.namespace(:wally) expect(subject.namespace_name).to eq([namespace]) expect(new_namespace.namespace_name).to eq([:stats, :wally]) end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
logstash-core-5.0.0.alpha4.snapshot3-java | spec/logstash/instrument/namespaced_metric_spec.rb |