leafy 0.0.3 → 0.1.0

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.
@@ -0,0 +1,100 @@
1
+ require 'leafy/core/timer'
2
+ require 'concurrent/atomic/atomic_boolean'
3
+
4
+ RSpec.describe Leafy::Core::Timer do
5
+
6
+ let(:clock) do
7
+ clock = Leafy::Core::Clock.new
8
+ # a mock clock that increments its ticker by 50msec per call
9
+ def clock.tick
10
+ @ticks = @ticks.to_i + 50000000
11
+ end
12
+ clock
13
+ end
14
+
15
+ let(:reservoir) { double('Reservoir') }
16
+
17
+ let(:timer) { Leafy::Core::Timer.new(reservoir, clock) }
18
+
19
+ it 'hasRates' do
20
+ expect(timer.count).to eq 0
21
+
22
+ expect(timer.mean_rate).to eq 0
23
+
24
+ expect(timer.one_minute_rate).to eq 0
25
+
26
+ expect(timer.five_minute_rate).to eq 0
27
+
28
+ expect(timer.fifteen_minute_rate).to eq 0
29
+ end
30
+
31
+
32
+ it 'updatesTheCountOnUpdates' do
33
+ allow(reservoir).to receive(:update).with(2000000000)
34
+ expect(timer.count).to eq 0
35
+
36
+ timer.update(2)
37
+
38
+ expect(timer.count).to eq 1
39
+ end
40
+
41
+
42
+ it 'timesCallableInstances' do
43
+ allow(reservoir).to receive(:update).with(50000000)
44
+
45
+ value = timer.time { "one" }
46
+
47
+ expect(timer.count).to eq 1
48
+
49
+ expect(value).to eq 'one'
50
+ end
51
+
52
+
53
+ it 'timesRunnableInstances' do
54
+ allow(reservoir).to receive(:update).with(50000000)
55
+
56
+ called = Concurrent::AtomicBoolean.new(false)
57
+ timer.time { called.value = true }
58
+
59
+ expect(timer.count).to eq 1
60
+
61
+ expect(called.value).to eq true
62
+ end
63
+
64
+
65
+ it 'timesContexts' do
66
+ allow(reservoir).to receive(:update).with(50000000)
67
+ timer.context.stop
68
+
69
+ expect(timer.count).to eq 1
70
+ end
71
+
72
+
73
+ it 'returnsTheSnapshotFromTheReservoir' do
74
+ snapshot = Object.new
75
+ allow(reservoir).to receive(:snapshot).and_return(snapshot)
76
+
77
+ expect(timer.snapshot).to eq snapshot
78
+ end
79
+
80
+
81
+ it 'ignoresNegativeValues' do
82
+ timer.update(-1)
83
+
84
+ expect(timer.count).to eq 0
85
+ end
86
+
87
+
88
+ it 'tryWithResourcesWork' do
89
+ allow(reservoir).to receive(:update).with(50000000)
90
+ expect(timer.count).to eq 0
91
+
92
+ dummy = 0
93
+ timer.context do |context|
94
+ #expect(context).isNotNull();
95
+ dummy += 1
96
+ end
97
+ expect(dummy).to eq 1
98
+ expect(timer.count).to eq 1
99
+ end
100
+ end
@@ -0,0 +1,126 @@
1
+ require 'leafy/core/sliding_window_reservoir'
2
+
3
+ RSpec.describe Leafy::Core::UniformSnapshot do
4
+
5
+ let(:snapshot) { Leafy::Core::UniformSnapshot.new(5, 1, 2, 3, 4) }
6
+ let(:empty_snapshot) { subject }
7
+
8
+ it 'smallQuantilesAreTheFirstValue' do
9
+ expect(Number[snapshot.value(0.0)]).to eql Number[1, 0.1]
10
+ end
11
+
12
+
13
+ it 'bigQuantilesAreTheLastValue' do
14
+ expect(Number[snapshot.value(1.0)]).to eql Number[5, 0.1]
15
+ end
16
+
17
+ it 'disallowsNotANumberQuantile' do
18
+ expect { snapshot.value('asd') }.to raise_error ArgumentError
19
+ end
20
+
21
+ it 'disallowsNegativeQuantile' do
22
+ expect { snapshot.value(-0.5) }.to raise_error ArgumentError
23
+ end
24
+
25
+ it 'disallowsQuantileOverOne' do
26
+ expect { snapshot.value(1.5) }.to raise_error ArgumentError
27
+ end
28
+
29
+
30
+ it 'hasAMedian' do
31
+ expect(Number[snapshot.median]).to eql Number[3, 0.1]
32
+ end
33
+
34
+
35
+ it 'hasAp75' do
36
+ expect(Number[snapshot.get_75th_percentile]).to eql Number[4.5, 0.1]
37
+ end
38
+
39
+
40
+ it 'hasAp95' do
41
+ expect(Number[snapshot.get_95th_percentile]).to eql Number[5.0, 0.1]
42
+ end
43
+
44
+
45
+ it 'hasAp98' do
46
+ expect(Number[snapshot.get_98th_percentile]).to eql Number[5.0, 0.1]
47
+ end
48
+
49
+
50
+ it 'hasAp99' do
51
+ expect(Number[snapshot.get_99th_percentile]).to eql Number[5.0, 0.1]
52
+ end
53
+
54
+
55
+ it 'hasAp999' do
56
+ expect(Number[snapshot.get_999th_percentile]).to eql Number[5.0, 0.1]
57
+ end
58
+
59
+
60
+ it 'hasValues' do
61
+ expect(snapshot.values).to match_array [1,2,3,4,5]
62
+ end
63
+
64
+
65
+ it 'hasASize' do
66
+ expect(snapshot.size).to eq 5
67
+ end
68
+
69
+
70
+
71
+ it 'dumpsToAStream' do
72
+ output = StringIO.new
73
+
74
+ snapshot.dump(output);
75
+
76
+ expect(output.string).to eq "1\n2\n3\n4\n5\n"
77
+ end
78
+
79
+
80
+ it 'calculatesTheMinimumValue' do
81
+ expect(snapshot.min).to eq 1
82
+ end
83
+
84
+
85
+ it 'calculatesTheMaximumValue' do
86
+ expect(snapshot.max).to eq 5
87
+ end
88
+
89
+
90
+ it 'calculatesTheMeanValue' do
91
+ expect(snapshot.mean).to eq 3.0
92
+ end
93
+
94
+
95
+ it 'calculatesTheStdDev' do
96
+ expect(Number[snapshot.std_dev]).to eql Number[1.5811, 0.01]
97
+ end
98
+
99
+
100
+ it 'calculatesAMinOfZeroForAnEmptySnapshot' do
101
+ expect(empty_snapshot.min).to eq 0.0
102
+ end
103
+
104
+
105
+ it 'calculatesAMaxOfZeroForAnEmptySnapshot' do
106
+ expect(empty_snapshot.max).to eq 0.0
107
+ end
108
+
109
+
110
+ it 'calculatesAMeanOfZeroForAnEmptySnapshot' do
111
+ expect(empty_snapshot.mean).to eq 0.0
112
+ end
113
+
114
+
115
+ it 'calculatesAStdDevOfZeroForAnEmptySnapshot' do
116
+ expect(empty_snapshot.std_dev).to eq 0.0
117
+ end
118
+
119
+
120
+ it 'calculatesAStdDevOfZeroForASingletonSnapshot' do
121
+ singleItemSnapshot = Leafy::Core::UniformSnapshot.new(1)
122
+
123
+ expect(singleItemSnapshot.std_dev).to eq 0.0
124
+ end
125
+
126
+ end
metadata CHANGED
@@ -1,26 +1,118 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: leafy
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.0.3
4
+ version: 0.1.0
5
5
  platform: ruby
6
6
  authors:
7
- - mkristian
7
+ - ''
8
8
  autorequire:
9
- bindir: bin
9
+ bindir: exe
10
10
  cert_chain: []
11
- date: 2018-05-28 00:00:00.000000000 Z
12
- dependencies: []
13
- description: old versions of leafy are obsolete
14
- email: meier.kristian@gmail.com
11
+ date: 2017-12-28 00:00:00.000000000 Z
12
+ dependencies:
13
+ - !ruby/object:Gem::Dependency
14
+ name: concurrent-ruby
15
+ requirement: !ruby/object:Gem::Requirement
16
+ requirements:
17
+ - - "~>"
18
+ - !ruby/object:Gem::Version
19
+ version: '1.0'
20
+ type: :runtime
21
+ prerelease: false
22
+ version_requirements: !ruby/object:Gem::Requirement
23
+ requirements:
24
+ - - "~>"
25
+ - !ruby/object:Gem::Version
26
+ version: '1.0'
27
+ - !ruby/object:Gem::Dependency
28
+ name: bundler
29
+ requirement: !ruby/object:Gem::Requirement
30
+ requirements:
31
+ - - "~>"
32
+ - !ruby/object:Gem::Version
33
+ version: '1.7'
34
+ type: :development
35
+ prerelease: false
36
+ version_requirements: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - "~>"
39
+ - !ruby/object:Gem::Version
40
+ version: '1.7'
41
+ - !ruby/object:Gem::Dependency
42
+ name: rake
43
+ requirement: !ruby/object:Gem::Requirement
44
+ requirements:
45
+ - - "~>"
46
+ - !ruby/object:Gem::Version
47
+ version: '12.0'
48
+ type: :development
49
+ prerelease: false
50
+ version_requirements: !ruby/object:Gem::Requirement
51
+ requirements:
52
+ - - "~>"
53
+ - !ruby/object:Gem::Version
54
+ version: '12.0'
55
+ - !ruby/object:Gem::Dependency
56
+ name: rspec
57
+ requirement: !ruby/object:Gem::Requirement
58
+ requirements:
59
+ - - "~>"
60
+ - !ruby/object:Gem::Version
61
+ version: '3.4'
62
+ type: :development
63
+ prerelease: false
64
+ version_requirements: !ruby/object:Gem::Requirement
65
+ requirements:
66
+ - - "~>"
67
+ - !ruby/object:Gem::Version
68
+ version: '3.4'
69
+ description: Port of Dropwizards metrics-core to pure ruby
70
+ email:
71
+ - ''
15
72
  executables: []
16
73
  extensions: []
17
74
  extra_rdoc_files: []
18
- files: []
19
- homepage: https://rubygems.org/gems/example
75
+ files:
76
+ - ".gitignore"
77
+ - ".rspec"
78
+ - ".travis.yml"
79
+ - Gemfile
80
+ - LICENSE
81
+ - README.md
82
+ - leafy.gemspec
83
+ - lib/leafy/core/adder.rb
84
+ - lib/leafy/core/clock.rb
85
+ - lib/leafy/core/console_reporter.rb
86
+ - lib/leafy/core/counter.rb
87
+ - lib/leafy/core/ewma.rb
88
+ - lib/leafy/core/gauge.rb
89
+ - lib/leafy/core/histogram.rb
90
+ - lib/leafy/core/meter.rb
91
+ - lib/leafy/core/metric_registry.rb
92
+ - lib/leafy/core/ratio_gauge.rb
93
+ - lib/leafy/core/scheduled_reporter.rb
94
+ - lib/leafy/core/sliding_window_reservoir.rb
95
+ - lib/leafy/core/snapshot.rb
96
+ - lib/leafy/core/timer.rb
97
+ - lib/leafy/core/uniform_snapshot.rb
98
+ - lib/leafy/core/version.rb
99
+ - puma.rb
100
+ - spec/console_reporter_spec.rb
101
+ - spec/counter_spec.rb
102
+ - spec/ewma_spec.rb
103
+ - spec/histogram_spec.rb
104
+ - spec/meter_spec.rb
105
+ - spec/metric_registry_spec.rb
106
+ - spec/ratio_gauge_spec.rb
107
+ - spec/scheduled_reporter_spec.rb
108
+ - spec/sliging_window_reservoir_spec.rb
109
+ - spec/spec_helper.rb
110
+ - spec/timer_spec.rb
111
+ - spec/uniform_snapshot_spec.rb
112
+ homepage: https://github.com/leafy-metrics/leafy
20
113
  licenses:
21
- - MIT
22
- metadata:
23
- source_code_uri: https://github.com/example/example
114
+ - APL2
115
+ metadata: {}
24
116
  post_install_message:
25
117
  rdoc_options: []
26
118
  require_paths:
@@ -29,7 +121,7 @@ required_ruby_version: !ruby/object:Gem::Requirement
29
121
  requirements:
30
122
  - - ">="
31
123
  - !ruby/object:Gem::Version
32
- version: '0'
124
+ version: 2.2.0
33
125
  required_rubygems_version: !ruby/object:Gem::Requirement
34
126
  requirements:
35
127
  - - ">="
@@ -37,8 +129,20 @@ required_rubygems_version: !ruby/object:Gem::Requirement
37
129
  version: '0'
38
130
  requirements: []
39
131
  rubyforge_project:
40
- rubygems_version: 2.7.6
132
+ rubygems_version: 2.5.1
41
133
  signing_key:
42
134
  specification_version: 4
43
- summary: old versions of leafy are obsolete
44
- test_files: []
135
+ summary: Port of Dropwizards metrics-core to pure ruby
136
+ test_files:
137
+ - spec/console_reporter_spec.rb
138
+ - spec/counter_spec.rb
139
+ - spec/ewma_spec.rb
140
+ - spec/histogram_spec.rb
141
+ - spec/meter_spec.rb
142
+ - spec/metric_registry_spec.rb
143
+ - spec/ratio_gauge_spec.rb
144
+ - spec/scheduled_reporter_spec.rb
145
+ - spec/sliging_window_reservoir_spec.rb
146
+ - spec/spec_helper.rb
147
+ - spec/timer_spec.rb
148
+ - spec/uniform_snapshot_spec.rb