explainpmt / explainpmt

This URL has Read+Write access

explainpmt / script / benchmarker
100644 19 lines (15 sloc) 0.477 kb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#!/usr/bin/ruby
 
if ARGV.empty?
  puts "Usage: benchmarker times 'Person.expensive_way' 'Person.another_expensive_way' ..."
  exit
end
 
require File.dirname(__FILE__) + '/../config/environment'
require 'benchmark'
include Benchmark
 
# Don't include compilation in the benchmark
ARGV[1..-1].each { |expression| eval(expression) }
 
bm(6) do |x|
  ARGV[1..-1].each_with_index do |expression, idx|
    x.report("##{idx + 1}") { ARGV[0].to_i.times { eval(expression) } }
  end
end