2013-12-14 17:47:11 +00:00
|
|
|
module Workbench
|
|
|
|
class Benchmark
|
|
|
|
class << self
|
|
|
|
def describe_engines engines
|
|
|
|
@@engines = engines
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
TERMINAL_WIDTH = 60
|
|
|
|
BM_WIDTH = 46
|
|
|
|
|
|
|
|
def initialize args, &block
|
|
|
|
puts '#' * TERMINAL_WIDTH
|
|
|
|
puts '##' + args[:title].center(TERMINAL_WIDTH - 4) + '##'
|
2013-12-14 17:54:35 +00:00
|
|
|
puts '#' * TERMINAL_WIDTH
|
2013-12-14 17:47:11 +00:00
|
|
|
|
|
|
|
::Benchmark.bm(TERMINAL_WIDTH - BM_WIDTH) do |benchmark|
|
|
|
|
@@engines.each do |name, attrs|
|
2013-12-14 17:54:35 +00:00
|
|
|
GC.start
|
2013-12-14 17:47:11 +00:00
|
|
|
benchmark.report(name) do
|
|
|
|
args[:loops].times{ yield(name, attrs) }
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
puts
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|