statsd-instrument 3.0.0.pre2 → 3.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (76) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/lint.yml +22 -0
  3. data/.github/workflows/tests.yml +31 -0
  4. data/.rubocop.yml +3 -13
  5. data/CHANGELOG.md +43 -0
  6. data/Gemfile +8 -2
  7. data/README.md +6 -3
  8. data/Rakefile +7 -7
  9. data/benchmark/send-metrics-to-dev-null-log +12 -11
  10. data/benchmark/send-metrics-to-local-udp-receiver +16 -15
  11. data/bin/rake +29 -0
  12. data/bin/rubocop +29 -0
  13. data/lib/statsd-instrument.rb +1 -1
  14. data/lib/statsd/instrument.rb +112 -145
  15. data/lib/statsd/instrument/assertions.rb +200 -208
  16. data/lib/statsd/instrument/batched_udp_sink.rb +159 -0
  17. data/lib/statsd/instrument/capture_sink.rb +23 -19
  18. data/lib/statsd/instrument/client.rb +410 -306
  19. data/lib/statsd/instrument/datagram.rb +69 -65
  20. data/lib/statsd/instrument/datagram_builder.rb +81 -77
  21. data/lib/statsd/instrument/dogstatsd_datagram.rb +76 -72
  22. data/lib/statsd/instrument/dogstatsd_datagram_builder.rb +68 -64
  23. data/lib/statsd/instrument/environment.rb +88 -77
  24. data/lib/statsd/instrument/expectation.rb +96 -96
  25. data/lib/statsd/instrument/helpers.rb +11 -7
  26. data/lib/statsd/instrument/log_sink.rb +20 -16
  27. data/lib/statsd/instrument/matchers.rb +93 -74
  28. data/lib/statsd/instrument/null_sink.rb +12 -8
  29. data/lib/statsd/instrument/railtie.rb +11 -7
  30. data/lib/statsd/instrument/rubocop.rb +8 -8
  31. data/lib/statsd/instrument/rubocop/measure_as_dist_argument.rb +1 -1
  32. data/lib/statsd/instrument/rubocop/metaprogramming_positional_arguments.rb +2 -2
  33. data/lib/statsd/instrument/rubocop/metric_prefix_argument.rb +1 -1
  34. data/lib/statsd/instrument/rubocop/metric_return_value.rb +2 -2
  35. data/lib/statsd/instrument/rubocop/metric_value_keyword_argument.rb +1 -1
  36. data/lib/statsd/instrument/rubocop/positional_arguments.rb +4 -4
  37. data/lib/statsd/instrument/rubocop/singleton_configuration.rb +1 -1
  38. data/lib/statsd/instrument/rubocop/splat_arguments.rb +2 -2
  39. data/lib/statsd/instrument/statsd_datagram_builder.rb +12 -8
  40. data/lib/statsd/instrument/strict.rb +1 -6
  41. data/lib/statsd/instrument/udp_sink.rb +49 -47
  42. data/lib/statsd/instrument/version.rb +1 -1
  43. data/statsd-instrument.gemspec +4 -8
  44. data/test/assertions_test.rb +199 -167
  45. data/test/benchmark/clock_gettime.rb +1 -1
  46. data/test/benchmark/default_tags.rb +9 -9
  47. data/test/benchmark/metrics.rb +8 -8
  48. data/test/benchmark/tags.rb +4 -4
  49. data/test/capture_sink_test.rb +14 -14
  50. data/test/client_test.rb +96 -96
  51. data/test/datagram_builder_test.rb +55 -55
  52. data/test/datagram_test.rb +5 -5
  53. data/test/dogstatsd_datagram_builder_test.rb +37 -37
  54. data/test/environment_test.rb +30 -21
  55. data/test/helpers/rubocop_helper.rb +12 -9
  56. data/test/helpers_test.rb +15 -15
  57. data/test/integration_test.rb +7 -7
  58. data/test/log_sink_test.rb +4 -4
  59. data/test/matchers_test.rb +54 -54
  60. data/test/null_sink_test.rb +4 -4
  61. data/test/rubocop/measure_as_dist_argument_test.rb +2 -2
  62. data/test/rubocop/metaprogramming_positional_arguments_test.rb +2 -2
  63. data/test/rubocop/metric_prefix_argument_test.rb +2 -2
  64. data/test/rubocop/metric_return_value_test.rb +6 -6
  65. data/test/rubocop/metric_value_keyword_argument_test.rb +3 -3
  66. data/test/rubocop/positional_arguments_test.rb +12 -12
  67. data/test/rubocop/singleton_configuration_test.rb +8 -8
  68. data/test/rubocop/splat_arguments_test.rb +2 -2
  69. data/test/statsd_datagram_builder_test.rb +6 -6
  70. data/test/statsd_instrumentation_test.rb +122 -122
  71. data/test/statsd_test.rb +69 -67
  72. data/test/test_helper.rb +19 -10
  73. data/test/udp_sink_test.rb +147 -49
  74. metadata +12 -92
  75. data/.github/workflows/ci.yml +0 -49
  76. data/.rubocop-https---shopify-github-io-ruby-style-guide-rubocop-yml +0 -1027
@@ -1,6 +1,6 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'benchmark/ips'
3
+ require "benchmark/ips"
4
4
 
5
5
  Benchmark.ips do |bench|
6
6
  bench.report("Process.clock_gettime in milliseconds (int)") do
@@ -1,21 +1,21 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'statsd-instrument'
4
- require 'benchmark/ips'
3
+ require "statsd-instrument"
4
+ require "benchmark/ips"
5
5
 
6
6
  StatsD.logger = Logger.new(File::NULL)
7
7
 
8
8
  class Suite
9
9
  def warming(*args)
10
10
  StatsD.default_tags = if args[0] == "with default tags"
11
- { first_tag: 'first_value', second_tag: 'second_value' }
11
+ { first_tag: "first_value", second_tag: "second_value" }
12
12
  end
13
13
  puts "warming with default tags: #{StatsD.default_tags}"
14
14
  end
15
15
 
16
16
  def running(*args)
17
17
  StatsD.default_tags = if args[0] == "with default tags"
18
- { first_tag: 'first_value', second_tag: 'second_value' }
18
+ { first_tag: "first_value", second_tag: "second_value" }
19
19
  end
20
20
  puts "running with default tags: #{StatsD.default_tags}"
21
21
  end
@@ -32,15 +32,15 @@ suite = Suite.new
32
32
  Benchmark.ips do |bench|
33
33
  bench.config(suite: suite)
34
34
  bench.report("without default tags") do
35
- StatsD.increment('GoogleBase.insert', tags: {
36
- first_tag: 'first_value',
37
- second_tag: 'second_value',
38
- third_tag: 'third_value',
35
+ StatsD.increment("GoogleBase.insert", tags: {
36
+ first_tag: "first_value",
37
+ second_tag: "second_value",
38
+ third_tag: "third_value",
39
39
  })
40
40
  end
41
41
 
42
42
  bench.report("with default tags") do
43
- StatsD.increment('GoogleBase.insert', tags: { third_tag: 'third_value' })
43
+ StatsD.increment("GoogleBase.insert", tags: { third_tag: "third_value" })
44
44
  end
45
45
 
46
46
  bench.compare!
@@ -1,7 +1,7 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'statsd-instrument'
4
- require 'benchmark/ips'
3
+ require "statsd-instrument"
4
+ require "benchmark/ips"
5
5
 
6
6
  def helper_function
7
7
  a = 10
@@ -12,28 +12,28 @@ end
12
12
 
13
13
  Benchmark.ips do |bench|
14
14
  bench.report("increment metric benchmark") do
15
- StatsD.increment('GoogleBase.insert', 10)
15
+ StatsD.increment("GoogleBase.insert", 10)
16
16
  end
17
17
 
18
18
  bench.report("measure metric benchmark") do
19
- StatsD.measure('helper_function') do
19
+ StatsD.measure("helper_function") do
20
20
  helper_function
21
21
  end
22
22
  end
23
23
 
24
24
  bench.report("gauge metric benchmark") do
25
- StatsD.gauge('GoogleBase.insert', 12)
25
+ StatsD.gauge("GoogleBase.insert", 12)
26
26
  end
27
27
 
28
28
  bench.report("set metric benchmark") do
29
- StatsD.set('GoogleBase.customers', "12345", sample_rate: 1.0)
29
+ StatsD.set("GoogleBase.customers", "12345", sample_rate: 1.0)
30
30
  end
31
31
 
32
32
  bench.report("event metric benchmark") do
33
- StatsD.event('Event Title', "12345")
33
+ StatsD.event("Event Title", "12345")
34
34
  end
35
35
 
36
36
  bench.report("service check metric benchmark") do
37
- StatsD.service_check('shipit.redis_connection', 'ok')
37
+ StatsD.service_check("shipit.redis_connection", "ok")
38
38
  end
39
39
  end
@@ -1,15 +1,15 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'statsd-instrument'
4
- require 'benchmark/ips'
3
+ require "statsd-instrument"
4
+ require "benchmark/ips"
5
5
 
6
6
  Benchmark.ips do |bench|
7
7
  bench.report("normalized tags with simple hash") do
8
- StatsD::Instrument::Metric.normalize_tags(tag: 'value')
8
+ StatsD::Instrument::Metric.normalize_tags(tag: "value")
9
9
  end
10
10
 
11
11
  bench.report("normalized tags with simple array") do
12
- StatsD::Instrument::Metric.normalize_tags(['test:test'])
12
+ StatsD::Instrument::Metric.normalize_tags(["test:test"])
13
13
  end
14
14
 
15
15
  bench.report("normalized tags with large hash") do
@@ -1,23 +1,23 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'test_helper'
3
+ require "test_helper"
4
4
 
5
5
  class CaptureSinkTest < Minitest::Test
6
6
  def test_capture_sink_captures_datagram_instances
7
7
  capture_sink = StatsD::Instrument::CaptureSink.new(parent: [])
8
- capture_sink << 'foo:1|c'
8
+ capture_sink << "foo:1|c"
9
9
 
10
- assert_equal 1, capture_sink.datagrams.length
11
- assert_kind_of StatsD::Instrument::Datagram, capture_sink.datagrams.first
12
- assert_equal 'foo:1|c', capture_sink.datagrams.first.source
10
+ assert_equal(1, capture_sink.datagrams.length)
11
+ assert_kind_of(StatsD::Instrument::Datagram, capture_sink.datagrams.first)
12
+ assert_equal("foo:1|c", capture_sink.datagrams.first.source)
13
13
  end
14
14
 
15
15
  def test_capture_sink_sends_datagrams_to_parent
16
16
  parent = []
17
17
  capture_sink = StatsD::Instrument::CaptureSink.new(parent: parent)
18
- capture_sink << 'foo:1|c' << 'bar:1|c'
18
+ capture_sink << "foo:1|c" << "bar:1|c"
19
19
 
20
- assert_equal ['foo:1|c', 'bar:1|c'], parent
20
+ assert_equal(["foo:1|c", "bar:1|c"], parent)
21
21
  end
22
22
 
23
23
  def test_nesting_capture_sink_instances
@@ -25,18 +25,18 @@ class CaptureSinkTest < Minitest::Test
25
25
  outer_capture_sink = StatsD::Instrument::CaptureSink.new(parent: null_sink)
26
26
  inner_capture_sink = StatsD::Instrument::CaptureSink.new(parent: outer_capture_sink)
27
27
 
28
- outer_capture_sink << 'foo:1|c'
29
- inner_capture_sink << 'bar:1|c'
28
+ outer_capture_sink << "foo:1|c"
29
+ inner_capture_sink << "bar:1|c"
30
30
 
31
- assert_equal ['foo:1|c', 'bar:1|c'], outer_capture_sink.datagrams.map(&:source)
32
- assert_equal ['bar:1|c'], inner_capture_sink.datagrams.map(&:source)
31
+ assert_equal(["foo:1|c", "bar:1|c"], outer_capture_sink.datagrams.map(&:source))
32
+ assert_equal(["bar:1|c"], inner_capture_sink.datagrams.map(&:source))
33
33
  end
34
34
 
35
35
  def test_using_a_different_datagram_class
36
36
  sink = StatsD::Instrument::CaptureSink.new(parent: [], datagram_class: String)
37
- sink << 'foo:1|c'
37
+ sink << "foo:1|c"
38
38
 
39
- assert sink.datagrams.all? { |datagram| datagram.is_a?(String) }
40
- assert_equal ['foo:1|c'], sink.datagrams
39
+ assert(sink.datagrams.all? { |datagram| datagram.is_a?(String) })
40
+ assert_equal(["foo:1|c"], sink.datagrams)
41
41
  end
42
42
  end
data/test/client_test.rb CHANGED
@@ -1,222 +1,222 @@
1
1
  # frozen_string_literal: true
2
2
 
3
- require 'test_helper'
3
+ require "test_helper"
4
4
 
5
5
  class ClientTest < Minitest::Test
6
6
  def setup
7
7
  @client = StatsD::Instrument::Client.new(datagram_builder_class: StatsD::Instrument::StatsDDatagramBuilder)
8
- @dogstatsd_client = StatsD::Instrument::Client.new(implementation: 'datadog')
8
+ @dogstatsd_client = StatsD::Instrument::Client.new(implementation: "datadog")
9
9
  end
10
10
 
11
11
  def test_client_from_env
12
12
  env = StatsD::Instrument::Environment.new(
13
- 'STATSD_ENV' => 'production',
14
- 'STATSD_SAMPLE_RATE' => '0.1',
15
- 'STATSD_PREFIX' => 'foo',
16
- 'STATSD_DEFAULT_TAGS' => 'shard:1,env:production',
17
- 'STATSD_IMPLEMENTATION' => 'statsd',
18
- 'STATSD_ADDR' => '1.2.3.4:8125',
13
+ "STATSD_ENV" => "production",
14
+ "STATSD_SAMPLE_RATE" => "0.1",
15
+ "STATSD_PREFIX" => "foo",
16
+ "STATSD_DEFAULT_TAGS" => "shard:1,env:production",
17
+ "STATSD_IMPLEMENTATION" => "statsd",
18
+ "STATSD_ADDR" => "1.2.3.4:8125",
19
19
  )
20
20
  client = StatsD::Instrument::Client.from_env(env)
21
21
 
22
- assert_equal 0.1, client.default_sample_rate
23
- assert_equal 'foo', client.prefix
24
- assert_equal ['shard:1', 'env:production'], client.default_tags
25
- assert_equal StatsD::Instrument::StatsDDatagramBuilder, client.datagram_builder_class
22
+ assert_equal(0.1, client.default_sample_rate)
23
+ assert_equal("foo", client.prefix)
24
+ assert_equal(["shard:1", "env:production"], client.default_tags)
25
+ assert_equal(StatsD::Instrument::StatsDDatagramBuilder, client.datagram_builder_class)
26
26
 
27
- assert_kind_of StatsD::Instrument::UDPSink, client.sink
28
- assert_equal '1.2.3.4', client.sink.host
29
- assert_equal 8125, client.sink.port
27
+ assert_kind_of(StatsD::Instrument::BatchedUDPSink, client.sink)
28
+ assert_equal("1.2.3.4", client.sink.host)
29
+ assert_equal(8125, client.sink.port)
30
30
  end
31
31
 
32
32
  def test_client_from_env_has_sensible_defaults
33
33
  env = StatsD::Instrument::Environment.new({})
34
34
  client = StatsD::Instrument::Client.from_env(env)
35
35
 
36
- assert_equal 1.0, client.default_sample_rate
37
- assert_nil client.prefix
38
- assert_nil client.default_tags
39
- assert_equal StatsD::Instrument::DogStatsDDatagramBuilder, client.datagram_builder_class
40
- assert_kind_of StatsD::Instrument::LogSink, client.sink
36
+ assert_equal(1.0, client.default_sample_rate)
37
+ assert_nil(client.prefix)
38
+ assert_nil(client.default_tags)
39
+ assert_equal(StatsD::Instrument::DogStatsDDatagramBuilder, client.datagram_builder_class)
40
+ assert_kind_of(StatsD::Instrument::LogSink, client.sink)
41
41
  end
42
42
 
43
43
  def test_client_from_env_with_overrides
44
44
  env = StatsD::Instrument::Environment.new(
45
- 'STATSD_SAMPLE_RATE' => '0.1',
46
- 'STATSD_PREFIX' => 'foo',
47
- 'STATSD_DEFAULT_TAGS' => 'shard:1,env:production',
48
- 'STATSD_IMPLEMENTATION' => 'statsd',
49
- 'STATSD_ADDR' => '1.2.3.4:8125',
45
+ "STATSD_SAMPLE_RATE" => "0.1",
46
+ "STATSD_PREFIX" => "foo",
47
+ "STATSD_DEFAULT_TAGS" => "shard:1,env:production",
48
+ "STATSD_IMPLEMENTATION" => "statsd",
49
+ "STATSD_ADDR" => "1.2.3.4:8125",
50
50
  )
51
51
  client = StatsD::Instrument::Client.from_env(env,
52
- prefix: 'bar', implementation: 'dogstatsd', sink: StatsD::Instrument::NullSink.new)
52
+ prefix: "bar", implementation: "dogstatsd", sink: StatsD::Instrument::NullSink.new)
53
53
 
54
- assert_equal 0.1, client.default_sample_rate
55
- assert_equal 'bar', client.prefix
56
- assert_equal ['shard:1', 'env:production'], client.default_tags
57
- assert_equal StatsD::Instrument::DogStatsDDatagramBuilder, client.datagram_builder_class
54
+ assert_equal(0.1, client.default_sample_rate)
55
+ assert_equal("bar", client.prefix)
56
+ assert_equal(["shard:1", "env:production"], client.default_tags)
57
+ assert_equal(StatsD::Instrument::DogStatsDDatagramBuilder, client.datagram_builder_class)
58
58
 
59
- assert_kind_of StatsD::Instrument::NullSink, client.sink
59
+ assert_kind_of(StatsD::Instrument::NullSink, client.sink)
60
60
  end
61
61
 
62
62
  def test_capture
63
63
  inner_datagrams = nil
64
64
 
65
- @client.increment('foo')
65
+ @client.increment("foo")
66
66
  outer_datagrams = @client.capture do
67
- @client.increment('bar')
67
+ @client.increment("bar")
68
68
  inner_datagrams = @client.capture do
69
- @client.increment('baz')
69
+ @client.increment("baz")
70
70
  end
71
71
  end
72
- @client.increment('quc')
72
+ @client.increment("quc")
73
73
 
74
- assert_equal ['bar', 'baz'], outer_datagrams.map(&:name)
75
- assert_equal ['baz'], inner_datagrams.map(&:name)
74
+ assert_equal(["bar", "baz"], outer_datagrams.map(&:name))
75
+ assert_equal(["baz"], inner_datagrams.map(&:name))
76
76
  end
77
77
 
78
78
  def test_metric_methods_return_truish_void
79
- assert @client.increment('foo')
80
- assert @client.measure('bar', 122.54)
81
- assert @client.set('baz', 123)
82
- assert @client.gauge('baz', 12.3)
79
+ assert(@client.increment("foo"))
80
+ assert(@client.measure("bar", 122.54))
81
+ assert(@client.set("baz", 123))
82
+ assert(@client.gauge("baz", 12.3))
83
83
  end
84
84
 
85
85
  def test_increment_with_default_value
86
- datagrams = @client.capture { @client.increment('foo') }
87
- assert_equal 1, datagrams.size
88
- assert_equal 'foo:1|c', datagrams.first.source
86
+ datagrams = @client.capture { @client.increment("foo") }
87
+ assert_equal(1, datagrams.size)
88
+ assert_equal("foo:1|c", datagrams.first.source)
89
89
  end
90
90
 
91
91
  def test_measure_with_value
92
- datagrams = @client.capture { @client.measure('foo', 122.54) }
93
- assert_equal 1, datagrams.size
94
- assert_equal 'foo:122.54|ms', datagrams.first.source
92
+ datagrams = @client.capture { @client.measure("foo", 122.54) }
93
+ assert_equal(1, datagrams.size)
94
+ assert_equal("foo:122.54|ms", datagrams.first.source)
95
95
  end
96
96
 
97
97
  def test_measure_with_block
98
98
  Process.stubs(:clock_gettime).with(Process::CLOCK_MONOTONIC).returns(0.1, 0.2)
99
99
  datagrams = @client.capture do
100
- @client.measure('foo') {}
100
+ @client.measure("foo") {}
101
101
  end
102
- assert_equal 1, datagrams.size
103
- assert_equal 'foo:100.0|ms', datagrams.first.source
102
+ assert_equal(1, datagrams.size)
103
+ assert_equal("foo:100.0|ms", datagrams.first.source)
104
104
  end
105
105
 
106
106
  def test_gauge
107
- datagrams = @client.capture { @client.gauge('foo', 123) }
108
- assert_equal 1, datagrams.size
109
- assert_equal 'foo:123|g', datagrams.first.source
107
+ datagrams = @client.capture { @client.gauge("foo", 123) }
108
+ assert_equal(1, datagrams.size)
109
+ assert_equal("foo:123|g", datagrams.first.source)
110
110
  end
111
111
 
112
112
  def test_set
113
- datagrams = @client.capture { @client.set('foo', 12345) }
114
- assert_equal 1, datagrams.size
115
- assert_equal 'foo:12345|s', datagrams.first.source
113
+ datagrams = @client.capture { @client.set("foo", 12345) }
114
+ assert_equal(1, datagrams.size)
115
+ assert_equal("foo:12345|s", datagrams.first.source)
116
116
  end
117
117
 
118
118
  def test_histogram
119
- datagrams = @dogstatsd_client.capture { @dogstatsd_client.histogram('foo', 12.44) }
120
- assert_equal 1, datagrams.size
121
- assert_equal 'foo:12.44|h', datagrams.first.source
119
+ datagrams = @dogstatsd_client.capture { @dogstatsd_client.histogram("foo", 12.44) }
120
+ assert_equal(1, datagrams.size)
121
+ assert_equal("foo:12.44|h", datagrams.first.source)
122
122
  end
123
123
 
124
124
  def test_distribution_with_value
125
- datagrams = @dogstatsd_client.capture { @dogstatsd_client.distribution('foo', 12.44) }
126
- assert_equal 1, datagrams.size
127
- assert_equal 'foo:12.44|d', datagrams.first.source
125
+ datagrams = @dogstatsd_client.capture { @dogstatsd_client.distribution("foo", 12.44) }
126
+ assert_equal(1, datagrams.size)
127
+ assert_equal("foo:12.44|d", datagrams.first.source)
128
128
  end
129
129
 
130
130
  def test_distribution_with_block
131
131
  Process.stubs(:clock_gettime).with(Process::CLOCK_MONOTONIC).returns(0.1, 0.2)
132
132
  datagrams = @dogstatsd_client.capture do
133
- @dogstatsd_client.distribution('foo') {}
133
+ @dogstatsd_client.distribution("foo") {}
134
134
  end
135
- assert_equal 1, datagrams.size
136
- assert_equal "foo:100.0|d", datagrams.first.source
135
+ assert_equal(1, datagrams.size)
136
+ assert_equal("foo:100.0|d", datagrams.first.source)
137
137
  end
138
138
 
139
139
  def test_latency_emits_ms_metric
140
140
  Process.stubs(:clock_gettime).with(Process::CLOCK_MONOTONIC).returns(0.1, 0.2)
141
141
  datagrams = @client.capture do
142
- @client.latency('foo') {}
142
+ @client.latency("foo") {}
143
143
  end
144
- assert_equal 1, datagrams.size
145
- assert_equal "foo:100.0|ms", datagrams.first.source
144
+ assert_equal(1, datagrams.size)
145
+ assert_equal("foo:100.0|ms", datagrams.first.source)
146
146
  end
147
147
 
148
148
  def test_latency_on_dogstatsd_prefers_distribution_metric_type
149
149
  Process.stubs(:clock_gettime).with(Process::CLOCK_MONOTONIC).returns(0.1, 0.2)
150
150
  datagrams = @dogstatsd_client.capture do
151
- @dogstatsd_client.latency('foo') {}
151
+ @dogstatsd_client.latency("foo") {}
152
152
  end
153
- assert_equal 1, datagrams.size
154
- assert_equal "foo:100.0|d", datagrams.first.source
153
+ assert_equal(1, datagrams.size)
154
+ assert_equal("foo:100.0|d", datagrams.first.source)
155
155
  end
156
156
 
157
157
  def test_latency_calls_block_even_when_not_sending_a_sample
158
158
  called = false
159
159
  @client.capture do
160
- @client.latency('foo', sample_rate: 0) { called = true }
160
+ @client.latency("foo", sample_rate: 0) { called = true }
161
161
  end
162
- assert called, "The block should have been called"
162
+ assert(called, "The block should have been called")
163
163
  end
164
164
 
165
165
  def test_service_check
166
- datagrams = @dogstatsd_client.capture { @dogstatsd_client.service_check('service', :ok) }
167
- assert_equal 1, datagrams.size
168
- assert_equal "_sc|service|0", datagrams.first.source
166
+ datagrams = @dogstatsd_client.capture { @dogstatsd_client.service_check("service", :ok) }
167
+ assert_equal(1, datagrams.size)
168
+ assert_equal("_sc|service|0", datagrams.first.source)
169
169
  end
170
170
 
171
171
  def test_event
172
- datagrams = @dogstatsd_client.capture { @dogstatsd_client.event('service', "event\ndescription") }
173
- assert_equal 1, datagrams.size
174
- assert_equal "_e{7,18}:service|event\\ndescription", datagrams.first.source
172
+ datagrams = @dogstatsd_client.capture { @dogstatsd_client.event("service", "event\ndescription") }
173
+ assert_equal(1, datagrams.size)
174
+ assert_equal("_e{7,18}:service|event\\ndescription", datagrams.first.source)
175
175
  end
176
176
 
177
177
  def test_no_prefix
178
- client = StatsD::Instrument::Client.new(prefix: 'foo')
178
+ client = StatsD::Instrument::Client.new(prefix: "foo")
179
179
  datagrams = client.capture do
180
- client.increment('bar')
181
- client.increment('bar', no_prefix: true)
180
+ client.increment("bar")
181
+ client.increment("bar", no_prefix: true)
182
182
  end
183
183
 
184
- assert_equal 2, datagrams.size
185
- assert_equal "foo.bar", datagrams[0].name
186
- assert_equal "bar", datagrams[1].name
184
+ assert_equal(2, datagrams.size)
185
+ assert_equal("foo.bar", datagrams[0].name)
186
+ assert_equal("bar", datagrams[1].name)
187
187
  end
188
188
 
189
189
  def test_default_tags_normalization
190
- client = StatsD::Instrument::Client.new(default_tags: { first_tag: 'f|irst_value', second_tag: 'sec,ond_value' })
190
+ client = StatsD::Instrument::Client.new(default_tags: { first_tag: "f|irst_value", second_tag: "sec,ond_value" })
191
191
  datagrams = client.capture do
192
- client.increment('bar', tags: ['th|ird_#,tag'])
192
+ client.increment("bar", tags: ["th|ird_#,tag"])
193
193
  end
194
194
 
195
- assert_includes datagrams.first.tags, 'first_tag:first_value'
196
- assert_includes datagrams.first.tags, 'second_tag:second_value'
197
- assert_includes datagrams.first.tags, 'third_#tag'
195
+ assert_includes(datagrams.first.tags, "first_tag:first_value")
196
+ assert_includes(datagrams.first.tags, "second_tag:second_value")
197
+ assert_includes(datagrams.first.tags, "third_#tag")
198
198
  end
199
199
 
200
200
  def test_sampling
201
- mock_sink = mock('sink')
201
+ mock_sink = mock("sink")
202
202
  mock_sink.stubs(:sample?).returns(false, true, false, false, true)
203
203
  mock_sink.expects(:<<).twice
204
204
 
205
205
  client = StatsD::Instrument::Client.new(sink: mock_sink)
206
- 5.times { client.increment('metric') }
206
+ 5.times { client.increment("metric") }
207
207
  end
208
208
 
209
209
  def test_clone_with_prefix_option
210
210
  # Both clients will use the same sink.
211
- mock_sink = mock('sink')
211
+ mock_sink = mock("sink")
212
212
  mock_sink.stubs(:sample?).returns(true)
213
213
  mock_sink.expects(:<<).with("metric:1|c").returns(mock_sink)
214
214
  mock_sink.expects(:<<).with("foo.metric:1|c").returns(mock_sink)
215
215
 
216
216
  original_client = StatsD::Instrument::Client.new(sink: mock_sink)
217
- client_with_other_options = original_client.clone_with_options(prefix: 'foo')
217
+ client_with_other_options = original_client.clone_with_options(prefix: "foo")
218
218
 
219
- original_client.increment('metric')
220
- client_with_other_options.increment('metric')
219
+ original_client.increment("metric")
220
+ client_with_other_options.increment("metric")
221
221
  end
222
222
  end