hitimes 2.0.0 → 3.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CONTRIBUTING.md +1 -1
- data/HISTORY.md +20 -3
- data/Manifest.txt +2 -17
- data/README.md +38 -43
- data/hitimes.gemspec +26 -0
- data/lib/hitimes/initialize.rb +83 -44
- data/lib/hitimes/instant.rb +9 -33
- data/lib/hitimes/interval.rb +15 -15
- data/lib/hitimes/metric.rb +18 -22
- data/lib/hitimes/mutexed_stats.rb +2 -4
- data/lib/hitimes/paths.rb +16 -14
- data/lib/hitimes/stats.rb +33 -33
- data/lib/hitimes/timed_metric.rb +43 -42
- data/lib/hitimes/timed_value_metric.rb +43 -43
- data/lib/hitimes/value_metric.rb +16 -15
- data/lib/hitimes/version.rb +3 -1
- data/lib/hitimes.rb +12 -11
- metadata +20 -113
- data/Rakefile +0 -19
- data/examples/benchmarks.rb +0 -113
- data/examples/stats.rb +0 -31
- data/spec/hitimes_spec.rb +0 -24
- data/spec/interval_spec.rb +0 -136
- data/spec/metric_spec.rb +0 -28
- data/spec/mutex_stats_spec.rb +0 -29
- data/spec/paths_spec.rb +0 -11
- data/spec/spec_helper.rb +0 -11
- data/spec/stats_spec.rb +0 -98
- data/spec/timed_metric_spec.rb +0 -155
- data/spec/timed_value_metric_spec.rb +0 -171
- data/spec/value_metric_spec.rb +0 -108
- data/spec/version_spec.rb +0 -7
- data/tasks/default.rake +0 -242
- data/tasks/this.rb +0 -208
- /data/{LICENSE → LICENSE.txt} +0 -0
data/tasks/default.rake
DELETED
@@ -1,242 +0,0 @@
|
|
1
|
-
# vim: syntax=ruby
|
2
|
-
require 'rake/clean'
|
3
|
-
require 'digest'
|
4
|
-
#------------------------------------------------------------------------------
|
5
|
-
# If you want to Develop on this project just run 'rake develop' and you'll
|
6
|
-
# have all you need to get going. If you want to use bundler for development,
|
7
|
-
# then run 'rake develop:using_bundler'
|
8
|
-
#------------------------------------------------------------------------------
|
9
|
-
namespace :develop do
|
10
|
-
|
11
|
-
# Install all the development and runtime dependencies of this gem using the
|
12
|
-
# gemspec.
|
13
|
-
task :default => 'Gemfile' do
|
14
|
-
require 'rubygems/dependency_installer'
|
15
|
-
installer = ::Gem::DependencyInstaller.new
|
16
|
-
puts "Installing bundler..."
|
17
|
-
installer.install 'bundler'
|
18
|
-
sh 'bundle install'
|
19
|
-
puts "\n\nNow run 'rake test'"
|
20
|
-
end
|
21
|
-
|
22
|
-
# Create a Gemfile that just references the gemspec
|
23
|
-
file 'Gemfile' => :gemspec do
|
24
|
-
File.open( "Gemfile", "w+" ) do |f|
|
25
|
-
f.puts "# DO NOT EDIT - This file is automatically generated"
|
26
|
-
f.puts "# Make changes to Manifest.txt and/or Rakefile and regenerate"
|
27
|
-
f.puts 'source "https://rubygems.org"'
|
28
|
-
f.puts 'gemspec'
|
29
|
-
end
|
30
|
-
end
|
31
|
-
end
|
32
|
-
desc "Bootstrap development"
|
33
|
-
task :develop => "develop:default"
|
34
|
-
|
35
|
-
#------------------------------------------------------------------------------
|
36
|
-
# Minitest - standard TestTask
|
37
|
-
#------------------------------------------------------------------------------
|
38
|
-
begin
|
39
|
-
require 'rake/testtask'
|
40
|
-
Rake::TestTask.new( :test ) do |t|
|
41
|
-
t.ruby_opts = %w[ -w ]
|
42
|
-
t.libs = %w[ lib spec test ]
|
43
|
-
t.pattern = "{test,spec}/**/{test_*,*_spec}.rb"
|
44
|
-
end
|
45
|
-
|
46
|
-
task :test_requirements
|
47
|
-
task :test => :test_requirements
|
48
|
-
task :default => :test
|
49
|
-
rescue LoadError
|
50
|
-
This.task_warning( 'test' )
|
51
|
-
end
|
52
|
-
|
53
|
-
#------------------------------------------------------------------------------
|
54
|
-
# RDoc - standard rdoc rake task, although we must make sure to use a more
|
55
|
-
# recent version of rdoc since it is the one that has 'tomdoc' markup
|
56
|
-
#------------------------------------------------------------------------------
|
57
|
-
begin
|
58
|
-
gem 'rdoc' # otherwise we get the wrong task from stdlib
|
59
|
-
require 'rdoc/task'
|
60
|
-
RDoc::Task.new do |t|
|
61
|
-
t.markup = 'tomdoc'
|
62
|
-
t.rdoc_dir = 'doc'
|
63
|
-
t.main = 'README.md'
|
64
|
-
t.title = "#{This.name} #{This.version}"
|
65
|
-
t.rdoc_files.include( FileList['*.{rdoc,md,txt}'], FileList['ext/**/*.c'],
|
66
|
-
FileList['lib/**/*.rb'] )
|
67
|
-
end
|
68
|
-
rescue StandardError, LoadError
|
69
|
-
This.task_warning( 'rdoc' )
|
70
|
-
end
|
71
|
-
|
72
|
-
#------------------------------------------------------------------------------
|
73
|
-
# Coverage - optional code coverage, rcov for 1.8 and simplecov for 1.9, so
|
74
|
-
# for the moment only rcov is listed.
|
75
|
-
#------------------------------------------------------------------------------
|
76
|
-
begin
|
77
|
-
require 'simplecov'
|
78
|
-
desc 'Run tests with code coverage'
|
79
|
-
task :coverage do
|
80
|
-
ENV['COVERAGE'] = 'true'
|
81
|
-
Rake::Task[:test].execute
|
82
|
-
end
|
83
|
-
CLOBBER << 'coverage' if File.directory?( 'coverage' )
|
84
|
-
rescue LoadError
|
85
|
-
This.task_warning( 'simplecov' )
|
86
|
-
end
|
87
|
-
|
88
|
-
#------------------------------------------------------------------------------
|
89
|
-
# Manifest - We want an explicit list of thos files that are to be packaged in
|
90
|
-
# the gem. Most of this is from Hoe.
|
91
|
-
#------------------------------------------------------------------------------
|
92
|
-
namespace 'manifest' do
|
93
|
-
desc "Check the manifest"
|
94
|
-
task :check => :clean do
|
95
|
-
files = FileList["**/*", ".*"].exclude( This.exclude_from_manifest ).to_a.sort
|
96
|
-
files = files.select{ |f| File.file?( f ) }
|
97
|
-
|
98
|
-
tmp = "Manifest.tmp"
|
99
|
-
File.open( tmp, 'w' ) do |f|
|
100
|
-
f.puts files.join("\n")
|
101
|
-
end
|
102
|
-
|
103
|
-
begin
|
104
|
-
sh "diff -du Manifest.txt #{tmp}"
|
105
|
-
ensure
|
106
|
-
rm tmp
|
107
|
-
end
|
108
|
-
puts "Manifest looks good"
|
109
|
-
end
|
110
|
-
|
111
|
-
desc "Generate the manifest"
|
112
|
-
task :generate => :clean do
|
113
|
-
files = %x[ git ls-files ].split("\n").sort
|
114
|
-
files.reject! { |f| f =~ This.exclude_from_manifest }
|
115
|
-
File.open( "Manifest.txt", "w" ) do |f|
|
116
|
-
f.puts files.join("\n")
|
117
|
-
end
|
118
|
-
end
|
119
|
-
end
|
120
|
-
|
121
|
-
#------------------------------------------------------------------------------
|
122
|
-
# Fixme - look for fixmes and report them
|
123
|
-
#------------------------------------------------------------------------------
|
124
|
-
namespace :fixme do
|
125
|
-
task :default => 'manifest:check' do
|
126
|
-
This.manifest.each do |file|
|
127
|
-
next if file == __FILE__
|
128
|
-
next unless file =~ %r/(txt|rb|md|rdoc|css|html|xml|css)\Z/
|
129
|
-
puts "FIXME: Rename #{file}" if file =~ /fixme/i
|
130
|
-
IO.readlines( file ).each_with_index do |line, idx|
|
131
|
-
prefix = "FIXME: #{file}:#{idx+1}".ljust(42)
|
132
|
-
puts "#{prefix} => #{line.strip}" if line =~ /fixme/i
|
133
|
-
end
|
134
|
-
end
|
135
|
-
end
|
136
|
-
|
137
|
-
def fixme_project_root
|
138
|
-
This.project_path( '../fixme' )
|
139
|
-
end
|
140
|
-
|
141
|
-
def fixme_project_path( subtree )
|
142
|
-
fixme_project_root.join( subtree )
|
143
|
-
end
|
144
|
-
|
145
|
-
def local_fixme_files
|
146
|
-
This.manifest.select { |p| p =~ %r|^tasks/| }
|
147
|
-
end
|
148
|
-
|
149
|
-
def outdated_fixme_files
|
150
|
-
local_fixme_files.select do |local|
|
151
|
-
upstream = fixme_project_path( local )
|
152
|
-
upstream.exist? &&
|
153
|
-
( Digest::SHA256.file( local ) != Digest::SHA256.file( upstream ) )
|
154
|
-
end
|
155
|
-
end
|
156
|
-
|
157
|
-
def fixme_up_to_date?
|
158
|
-
outdated_fixme_files.empty?
|
159
|
-
end
|
160
|
-
|
161
|
-
desc "See if the fixme tools are outdated"
|
162
|
-
task :outdated => :release_check do
|
163
|
-
if fixme_up_to_date? then
|
164
|
-
puts "Fixme files are up to date."
|
165
|
-
else
|
166
|
-
outdated_fixme_files.each do |f|
|
167
|
-
puts "#{f} is outdated"
|
168
|
-
end
|
169
|
-
end
|
170
|
-
end
|
171
|
-
|
172
|
-
desc "Update outdated fixme files"
|
173
|
-
task :update => :release_check do
|
174
|
-
if fixme_up_to_date? then
|
175
|
-
puts "Fixme files are already up to date."
|
176
|
-
else
|
177
|
-
puts "Updating fixme files:"
|
178
|
-
outdated_fixme_files.each do |local|
|
179
|
-
upstream = fixme_project_path( local )
|
180
|
-
puts " * #{local}"
|
181
|
-
FileUtils.cp( upstream, local )
|
182
|
-
end
|
183
|
-
puts "Use your git commands as appropriate."
|
184
|
-
end
|
185
|
-
end
|
186
|
-
end
|
187
|
-
desc "Look for fixmes and report them"
|
188
|
-
task :fixme => "fixme:default"
|
189
|
-
|
190
|
-
#------------------------------------------------------------------------------
|
191
|
-
# Gem Specification
|
192
|
-
#------------------------------------------------------------------------------
|
193
|
-
# Really this is only here to support those who use bundler
|
194
|
-
desc "Build the #{This.name}.gemspec file"
|
195
|
-
task :gemspec do
|
196
|
-
File.open( This.gemspec_file, "wb+" ) do |f|
|
197
|
-
f.puts "# DO NOT EDIT - This file is automatically generated"
|
198
|
-
f.puts "# Make changes to Manifest.txt and/or Rakefile and regenerate"
|
199
|
-
f.write This.platform_gemspec.to_ruby
|
200
|
-
end
|
201
|
-
end
|
202
|
-
|
203
|
-
# .rbc files from ruby 2.0
|
204
|
-
CLOBBER << FileList["**/*.rbc"]
|
205
|
-
|
206
|
-
# The standard gem packaging task, everyone has it.
|
207
|
-
require 'rubygems/package_task'
|
208
|
-
::Gem::PackageTask.new( This.platform_gemspec ) do
|
209
|
-
# nothing
|
210
|
-
end
|
211
|
-
|
212
|
-
#------------------------------------------------------------------------------
|
213
|
-
# Release - the steps we go through to do a final release, this is pulled from
|
214
|
-
# a compbination of mojombo's rakegem, hoe and hoe-git
|
215
|
-
#
|
216
|
-
# 1) make sure we are on the master branch
|
217
|
-
# 2) make sure there are no uncommitted items
|
218
|
-
# 3) check the manifest and make sure all looks good
|
219
|
-
# 4) build the gem
|
220
|
-
# 5) do an empty commit to have the commit message of the version
|
221
|
-
# 6) tag that commit as the version
|
222
|
-
# 7) push master
|
223
|
-
# 8) push the tag
|
224
|
-
# 7) pus the gem
|
225
|
-
#------------------------------------------------------------------------------
|
226
|
-
task :release_check do
|
227
|
-
unless `git branch` =~ /^\* master$/
|
228
|
-
abort "You must be on the master branch to release!"
|
229
|
-
end
|
230
|
-
unless `git status` =~ /^nothing to commit/m
|
231
|
-
abort "Nope, sorry, you have unfinished business"
|
232
|
-
end
|
233
|
-
end
|
234
|
-
|
235
|
-
desc "Create tag v#{This.version}, build and push #{This.platform_gemspec.full_name} to rubygems.org"
|
236
|
-
task :release => [ :release_check, 'manifest:check', :gem ] do
|
237
|
-
sh "git commit --allow-empty -a -m 'Release #{This.version}'"
|
238
|
-
sh "git tag -a -m 'v#{This.version}' v#{This.version}"
|
239
|
-
sh "git push origin master"
|
240
|
-
sh "git push origin v#{This.version}"
|
241
|
-
sh "gem push pkg/#{This.platform_gemspec.full_name}.gem"
|
242
|
-
end
|
data/tasks/this.rb
DELETED
@@ -1,208 +0,0 @@
|
|
1
|
-
require 'pathname'
|
2
|
-
|
3
|
-
# Public: A Class containing all the metadata and utilities needed to manage a
|
4
|
-
# ruby project.
|
5
|
-
class ThisProject
|
6
|
-
# The name of this project
|
7
|
-
attr_accessor :name
|
8
|
-
|
9
|
-
# The author's name
|
10
|
-
attr_accessor :author
|
11
|
-
|
12
|
-
# The email address of the author(s)
|
13
|
-
attr_accessor :email
|
14
|
-
|
15
|
-
# The homepage of this project
|
16
|
-
attr_accessor :homepage
|
17
|
-
|
18
|
-
# The regex of files to exclude from the manifest
|
19
|
-
attr_accessor :exclude_from_manifest
|
20
|
-
|
21
|
-
# The hash of Gem::Specifications keyed' by platform
|
22
|
-
attr_accessor :gemspecs
|
23
|
-
|
24
|
-
# Public: Initialize ThisProject
|
25
|
-
#
|
26
|
-
# Yields self
|
27
|
-
def initialize(&block)
|
28
|
-
@exclude_from_manifest = Regexp.union(/\.(git|DS_Store|fossa.yml)/,
|
29
|
-
/^(doc|coverage|pkg|tmp|Gemfile(\.lock)?)/,
|
30
|
-
/^[^\/]+\.gemspec/,
|
31
|
-
/\.(swp|jar|bundle|so|rvmrc|travis.yml|byebug_history|fossa.yml|ruby-version)$/,
|
32
|
-
/~$/)
|
33
|
-
@gemspecs = Hash.new
|
34
|
-
yield self if block_given?
|
35
|
-
end
|
36
|
-
|
37
|
-
# Public: return the version of ThisProject
|
38
|
-
#
|
39
|
-
# Search the ruby files in the project looking for the one that has the
|
40
|
-
# version string in it. This does not eval any code in the project, it parses
|
41
|
-
# the source code looking for the string.
|
42
|
-
#
|
43
|
-
# Returns a String version
|
44
|
-
def version
|
45
|
-
[ "lib/#{ name }.rb", "lib/#{ name }/version.rb" ].each do |v|
|
46
|
-
path = project_path( v )
|
47
|
-
line = path.read[/^\s*VERSION\s*=\s*.*/]
|
48
|
-
if line then
|
49
|
-
return line.match(/.*VERSION\s*=\s*['"](.*)['"]/)[1]
|
50
|
-
end
|
51
|
-
end
|
52
|
-
end
|
53
|
-
|
54
|
-
# Internal: Return a section of an RDoc file with the given section name
|
55
|
-
#
|
56
|
-
# path - the relative path in the project of the file to parse
|
57
|
-
# section_name - the section out of the file from which to parse data
|
58
|
-
#
|
59
|
-
# Retuns the text of the section as an array of paragrphs.
|
60
|
-
def section_of( file, section_name )
|
61
|
-
re = /^[=#]+ (.*)$/
|
62
|
-
sectional = project_path( file )
|
63
|
-
parts = sectional.read.split( re )[1..-1]
|
64
|
-
parts.map! { |p| p.strip }
|
65
|
-
|
66
|
-
sections = Hash.new
|
67
|
-
Hash[*parts].each do |k,v|
|
68
|
-
sections[k] = v.split("\n\n")
|
69
|
-
end
|
70
|
-
return sections[section_name]
|
71
|
-
end
|
72
|
-
|
73
|
-
# Internal: print out a warning about the give task
|
74
|
-
def task_warning( task )
|
75
|
-
warn "WARNING: '#{task}' tasks are not defined. Please run 'rake develop'"
|
76
|
-
end
|
77
|
-
|
78
|
-
# Internal: Return the full path to the file that is relative to the project
|
79
|
-
# root.
|
80
|
-
#
|
81
|
-
# path - the relative path of the file from the project root
|
82
|
-
#
|
83
|
-
# Returns the Pathname of the file
|
84
|
-
def project_path( *relative_path )
|
85
|
-
project_root.join( *relative_path )
|
86
|
-
end
|
87
|
-
|
88
|
-
# Internal: The absolute path of this file
|
89
|
-
#
|
90
|
-
# Returns the Pathname of this file.
|
91
|
-
def this_file_path
|
92
|
-
Pathname.new( __FILE__ ).expand_path
|
93
|
-
end
|
94
|
-
|
95
|
-
# Internal: The root directory of this project
|
96
|
-
#
|
97
|
-
# This is defined as being the directory that is in the path of this project
|
98
|
-
# that has the first Rakefile
|
99
|
-
#
|
100
|
-
# Returns the Pathname of the directory
|
101
|
-
def project_root
|
102
|
-
this_file_path.ascend do |p|
|
103
|
-
rakefile = p.join( 'Rakefile' )
|
104
|
-
return p if rakefile.exist?
|
105
|
-
end
|
106
|
-
end
|
107
|
-
|
108
|
-
# Internal: Returns the contents of the Manifest.txt file as an array
|
109
|
-
#
|
110
|
-
# Returns an Array of strings
|
111
|
-
def manifest
|
112
|
-
manifest_file = project_path( "Manifest.txt" )
|
113
|
-
abort "You need a Manifest.txt" unless manifest_file.readable?
|
114
|
-
manifest_file.readlines.map { |l| l.strip }
|
115
|
-
end
|
116
|
-
|
117
|
-
# Internal: Return the files that define the extensions
|
118
|
-
#
|
119
|
-
# Returns an Array
|
120
|
-
def extension_conf_files
|
121
|
-
manifest.grep( /extconf.rb\Z/ )
|
122
|
-
end
|
123
|
-
|
124
|
-
# Internal: Returns the gemspace associated with the current ruby platform
|
125
|
-
def platform_gemspec
|
126
|
-
gemspecs.fetch(platform) { This.ruby_gemspec }
|
127
|
-
end
|
128
|
-
|
129
|
-
def core_gemspec
|
130
|
-
Gem::Specification.new do |spec|
|
131
|
-
spec.name = name
|
132
|
-
spec.version = version
|
133
|
-
spec.author = author
|
134
|
-
spec.email = email
|
135
|
-
spec.homepage = homepage
|
136
|
-
|
137
|
-
spec.summary = summary
|
138
|
-
spec.description = description
|
139
|
-
spec.license = license
|
140
|
-
|
141
|
-
spec.files = manifest
|
142
|
-
spec.executables = spec.files.grep(/^bin/) { |f| File.basename(f) }
|
143
|
-
spec.test_files = spec.files.grep(/^spec/)
|
144
|
-
|
145
|
-
spec.extra_rdoc_files += spec.files.grep(/(txt|rdoc|md)$/)
|
146
|
-
spec.rdoc_options = [ "--main" , 'README.md',
|
147
|
-
"--markup", "tomdoc" ]
|
148
|
-
|
149
|
-
spec.required_ruby_version = '>= 2.2.2'
|
150
|
-
end
|
151
|
-
end
|
152
|
-
|
153
|
-
# Internal: Return the gemspec for the ruby platform
|
154
|
-
def ruby_gemspec( core = core_gemspec, &block )
|
155
|
-
yielding_gemspec( 'ruby', core, &block )
|
156
|
-
end
|
157
|
-
|
158
|
-
# Internal: Return the gemspec for the jruby platform
|
159
|
-
def java_gemspec( core = core_gemspec, &block )
|
160
|
-
yielding_gemspec( 'java', core, &block )
|
161
|
-
end
|
162
|
-
|
163
|
-
# Internal: give an initial spec and a key, create a new gemspec based off of
|
164
|
-
# it.
|
165
|
-
#
|
166
|
-
# This will force the new gemspecs 'platform' to be that of the key, since the
|
167
|
-
# only reason you would have multiple gemspecs at this point is to deal with
|
168
|
-
# different platforms.
|
169
|
-
def yielding_gemspec( key, core )
|
170
|
-
spec = gemspecs[key] ||= core.dup
|
171
|
-
spec.platform = key
|
172
|
-
yield spec if block_given?
|
173
|
-
return spec
|
174
|
-
end
|
175
|
-
|
176
|
-
# Internal: Return the platform of ThisProject at the current moment in time.
|
177
|
-
def platform
|
178
|
-
(RUBY_PLATFORM == "java") ? 'java' : Gem::Platform::RUBY
|
179
|
-
end
|
180
|
-
|
181
|
-
# Internal: Return the Description section of the README.rdoc file
|
182
|
-
def description_section
|
183
|
-
section_of( 'README.md', 'Description')
|
184
|
-
end
|
185
|
-
|
186
|
-
# Internal: Return the summary text from the README
|
187
|
-
def summary
|
188
|
-
description_section.first
|
189
|
-
end
|
190
|
-
|
191
|
-
# Internal: Return the full description text from the README
|
192
|
-
def description
|
193
|
-
description_section.join(" ").tr("\n", ' ').gsub(/[{}]/,'').gsub(/\[[^\]]+\]/,'') # strip rdoc
|
194
|
-
end
|
195
|
-
|
196
|
-
def license
|
197
|
-
license_file = project_path("LICENSE")
|
198
|
-
line = license_file.readlines.first
|
199
|
-
line.split(/\s+/).first
|
200
|
-
end
|
201
|
-
|
202
|
-
# Internal: The path to the gemspec file
|
203
|
-
def gemspec_file
|
204
|
-
project_path( "#{ name }.gemspec" )
|
205
|
-
end
|
206
|
-
end
|
207
|
-
|
208
|
-
This = ThisProject.new
|
/data/{LICENSE → LICENSE.txt}
RENAMED
File without changes
|