rack-perf 1.0.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.
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: b46c84481c69099693ff02502ed08c28fbcbb272
4
+ data.tar.gz: d54472dfab2c360d389fa60666d5a0dcd12eb697
5
+ SHA512:
6
+ metadata.gz: e41697451589ab21496781bff6887764b19adf889eaa4ba0f1fce9c1d32179ec138a6d234a202d9c7242e3c0eee9876ca0d9717c5d36423d69fe8d9bdb8f2878
7
+ data.tar.gz: fe2aa94d00af82c3c709e85b1f53628e2285c47438f7470f2ae768e8cbabc6f365c25ed2dd71cc04bcac1ec41ec36dadcb0171c2908ae30f65124d6a4421a97f
@@ -0,0 +1,5 @@
1
+ module Rack
2
+ class Perf
3
+ VERSION = "1.0.0"
4
+ end
5
+ end
data/lib/rack/perf.rb ADDED
@@ -0,0 +1,58 @@
1
+ module Rack
2
+ class Perf
3
+ require_relative "runtime/version"
4
+
5
+ attr_reader :endtime
6
+ private :endtime
7
+
8
+ attr_reader :endtime
9
+ private :endtime
10
+
11
+ attr_reader :label
12
+ private :label
13
+
14
+ def initialize(stack, label = "X-Perf-Timing")
15
+ @stack = stack
16
+ @label = label
17
+ end
18
+
19
+ def call(previous_state)
20
+ @state = previous_state
21
+ @startime = Time.now
22
+
23
+ @status, @headers, @body = stack.call(state)
24
+
25
+ @end = Time.now
26
+
27
+ unless headers.has_key?(label)
28
+ headers[label] = runtime
29
+ end
30
+
31
+ [status, headers, body]
32
+ end
33
+
34
+ private def runtime
35
+ (endtime - startime).to_s
36
+ end
37
+
38
+ private def stack
39
+ @stack
40
+ end
41
+
42
+ private def state
43
+ @state
44
+ end
45
+
46
+ private def headers
47
+ @headers
48
+ end
49
+
50
+ private def status
51
+ @status
52
+ end
53
+
54
+ private def body
55
+ @body
56
+ end
57
+ end
58
+ end
data/lib/rack-perf.rb ADDED
@@ -0,0 +1,4 @@
1
+
2
+ module Rack
3
+ require_relative "rack/perf"
4
+ end
metadata ADDED
@@ -0,0 +1,47 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: rack-perf
3
+ version: !ruby/object:Gem::Version
4
+ version: 1.0.0
5
+ platform: ruby
6
+ authors:
7
+ - Steven Lu
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2016-10-30 00:00:00.000000000 Z
12
+ dependencies: []
13
+ description: Rack middleware that records endpoint timing and status codes to Perf
14
+ email:
15
+ - steve@perf.sh
16
+ executables: []
17
+ extensions: []
18
+ extra_rdoc_files: []
19
+ files:
20
+ - lib/rack-perf.rb
21
+ - lib/rack/perf.rb
22
+ - lib/rack/perf/version.rb
23
+ homepage: https://github.com/perflabs/rack-perf
24
+ licenses:
25
+ - GPL-3.0
26
+ metadata: {}
27
+ post_install_message:
28
+ rdoc_options: []
29
+ require_paths:
30
+ - lib
31
+ required_ruby_version: !ruby/object:Gem::Requirement
32
+ requirements:
33
+ - - ">="
34
+ - !ruby/object:Gem::Version
35
+ version: '0'
36
+ required_rubygems_version: !ruby/object:Gem::Requirement
37
+ requirements:
38
+ - - ">="
39
+ - !ruby/object:Gem::Version
40
+ version: '0'
41
+ requirements: []
42
+ rubyforge_project:
43
+ rubygems_version: 2.5.1
44
+ signing_key:
45
+ specification_version: 4
46
+ summary: Rack middleware that records endpoint timing and status codes to Perf
47
+ test_files: []