-
-
Notifications
You must be signed in to change notification settings - Fork 405
/
statsd_subscriber_spec.rb
76 lines (61 loc) 路 2.2 KB
/
statsd_subscriber_spec.rb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
require 'helper'
require 'flipper/adapters/memory'
require 'flipper/instrumentation/statsd'
describe Flipper::Instrumentation::StatsdSubscriber do
let(:statsd_client) { Statsd.new }
let(:socket) { FakeUDPSocket.new }
let(:adapter) { Flipper::Adapters::Memory.new }
let(:flipper) {
Flipper.new(adapter, :instrumenter => ActiveSupport::Notifications)
}
let(:user) { user = Struct.new(:flipper_id).new('1') }
before do
described_class.client = statsd_client
Thread.current[:statsd_socket] = socket
end
after do
described_class.client = nil
Thread.current[:statsd_socket] = nil
end
def assert_timer(metric)
regex = /#{Regexp.escape metric}\:\d+\|ms/
socket.buffer.detect { |op| op.first =~ regex }.should_not be_nil
end
def assert_counter(metric)
socket.buffer.detect { |op| op.first == "#{metric}:1|c" }.should_not be_nil
end
context "for enabled feature" do
it "updates feature metrics when calls happen" do
flipper[:stats].enable(user)
assert_timer 'flipper.feature_operation.enable'
flipper[:stats].enabled?(user)
assert_timer 'flipper.feature_operation.enabled'
assert_counter 'flipper.feature.stats.enabled'
end
end
context "for disabled feature" do
it "updates feature metrics when calls happen" do
flipper[:stats].disable(user)
assert_timer 'flipper.feature_operation.disable'
flipper[:stats].enabled?(user)
assert_timer 'flipper.feature_operation.enabled'
assert_counter 'flipper.feature.stats.disabled'
end
end
it "updates adapter metrics when calls happen" do
flipper[:stats].enable(user)
assert_timer 'flipper.adapter.memory.enable'
flipper[:stats].enabled?(user)
assert_timer 'flipper.adapter.memory.get'
flipper[:stats].disable(user)
assert_timer 'flipper.adapter.memory.disable'
end
it "updates gate metrics when calls happen" do
flipper[:stats].enable(user)
flipper[:stats].enabled?(user)
assert_timer 'flipper.gate_operation.boolean.open'
assert_timer 'flipper.feature.stats.gate_operation.boolean.open'
assert_counter 'flipper.feature.stats.gate.actor.open'
assert_counter 'flipper.feature.stats.gate.boolean.closed'
end
end