1
0
Fork 0
template_engine_comparison/lib/workbench/benchmark.rb

30 lines
617 B
Ruby
Raw Normal View History

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