1
0

30 lines
617 B
Ruby
Raw Normal View History

2013-12-15 00:47:11 +07: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-15 00:54:35 +07:00
puts '#' * TERMINAL_WIDTH
2013-12-15 00:47:11 +07:00
::Benchmark.bm(TERMINAL_WIDTH - BM_WIDTH) do |benchmark|
@@engines.each do |name, attrs|
2013-12-15 00:54:35 +07:00
GC.start
2013-12-15 00:47:11 +07:00
benchmark.report(name) do
args[:loops].times{ yield(name, attrs) }
end
end
end
puts
end
end
end