aboutsummaryrefslogblamecommitdiffstats
path: root/railties/lib/commands/perform/benchmarker.rb
blob: 7e14de7cc3d59a73558554626c8b5ee1ad592cc3 (plain) (tree)
1
2
3
4
5
6
7
8






                                                                                           
                                          


                   


                                                  




                                                                       
#!/usr/local/bin/ruby

if ARGV.empty?
  puts "Usage: benchmarker times 'Person.expensive_way' 'Person.another_expensive_way' ..."
  exit 
end

require RAILS_ROOT + '/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