beasure 0.0.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 (3) hide show
  1. checksums.yaml +7 -0
  2. data/lib/beasure.rb +30 -0
  3. metadata +44 -0
checksums.yaml ADDED
@@ -0,0 +1,7 @@
1
+ ---
2
+ SHA1:
3
+ metadata.gz: b993d5ccc54bbc50da3eb1cf88d53599c909152f
4
+ data.tar.gz: 1820541f452e1efeaa52ca8753de859d00f9a10c
5
+ SHA512:
6
+ metadata.gz: 439e029e5c9c365327954535cd49fdc4d2fd968c0cc4a3d5004062ae189654122b2e066b4b0e7210ce0daa07cccc757a3f2da642abb6133c417902ed4dec46e7
7
+ data.tar.gz: dde9c2464a6dc7bbe0b08dcf84a777bb500dfd2535fa5b019f1a98274b09f3aac09eb162ef580273afddccd21ddd97775c6cadff07e4fe0e7ac14b666eb2e45c
data/lib/beasure.rb ADDED
@@ -0,0 +1,30 @@
1
+ class Beasure
2
+ require "json"
3
+ require "benchmark"
4
+
5
+ def self.perform(&block)
6
+ no_gc = (ARGV[0] == "--no-gc")
7
+ if no_gc
8
+ GC.disable
9
+ else
10
+ # collect memory allocated during library loading
11
+ # and our own code before the measurement
12
+ GC.start
13
+ end
14
+ memory_before = `ps -o rss= -p #{Process.pid}`.to_i / 1024
15
+ gc_stat_before = GC.stat
16
+ time = Benchmark.realtime do
17
+ yield
18
+ end
19
+ GC.start(full_mark: true, immediate_sweep: true, immediate_mark: false) unless no_gc
20
+ gc_stat_after = GC.stat
21
+ memory_after = `ps -o rss= -p #{Process.pid}`.to_i / 1024
22
+ puts({
23
+ RUBY_VERSION => {
24
+ gc: no_gc ? 'disabled' : 'enabled',
25
+ time: time.round(2),
26
+ gc_count: gc_stat_after[:count] - gc_stat_before[:count], memory: "%d MB" % (memory_after - memory_before)
27
+ }
28
+ }.to_json)
29
+ end
30
+ end
metadata ADDED
@@ -0,0 +1,44 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: beasure
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.0.1
5
+ platform: ruby
6
+ authors:
7
+ - Bachdx
8
+ autorequire:
9
+ bindir: bin
10
+ cert_chain: []
11
+ date: 2018-01-02 00:00:00.000000000 Z
12
+ dependencies: []
13
+ description: A simple gem to measure your ruby code
14
+ email: bachdx.hut@gmail.com
15
+ executables: []
16
+ extensions: []
17
+ extra_rdoc_files: []
18
+ files:
19
+ - lib/beasure.rb
20
+ homepage: http://rubygems.org/gems/beasure
21
+ licenses:
22
+ - MIT
23
+ metadata: {}
24
+ post_install_message:
25
+ rdoc_options: []
26
+ require_paths:
27
+ - lib
28
+ required_ruby_version: !ruby/object:Gem::Requirement
29
+ requirements:
30
+ - - ">="
31
+ - !ruby/object:Gem::Version
32
+ version: '0'
33
+ required_rubygems_version: !ruby/object:Gem::Requirement
34
+ requirements:
35
+ - - ">="
36
+ - !ruby/object:Gem::Version
37
+ version: '0'
38
+ requirements: []
39
+ rubyforge_project:
40
+ rubygems_version: 2.6.11
41
+ signing_key:
42
+ specification_version: 4
43
+ summary: Beasure!
44
+ test_files: []