From b6dbffcd89ab051d49dd9ea8dc84f446000c82cd Mon Sep 17 00:00:00 2001 From: nobu Date: Fri, 6 Mar 2015 01:33:43 +0000 Subject: driver.rb: load-rawdata * benchmark/driver.rb: add --load-rawdata option to load dumped rawdata and just output it without actual benchmark. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@49869 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- benchmark/driver.rb | 32 +++++++++++++++++++++++++++++++- 1 file changed, 31 insertions(+), 1 deletion(-) (limited to 'benchmark') diff --git a/benchmark/driver.rb b/benchmark/driver.rb index 0a4a13696d..defe3c30be 100644 --- a/benchmark/driver.rb +++ b/benchmark/driver.rb @@ -29,6 +29,25 @@ class BenchmarkDriver end end + def self.load(input, type, opt) + attrs = [:executables, :results] + case type + when 'yaml' + require 'yaml' + h = YAML.load(input) + when 'json' + require 'json' + h = JSON.load(input) + else + h = eval(input.read) + end + obj = allocate + obj.instance_variable_set("@execs", h[:executables] || h["executables"]) + obj.instance_variable_set("@results", h[:results] || h["results"]) + obj.instance_variable_set("@opt", opt) + obj + end + def output *args puts(*args) @output and @output.puts(*args) @@ -351,6 +370,9 @@ if __FILE__ == $0 o.on('--rawdata-output [FILE]', 'output rawdata'){|r| opt[:rawdata_output] = r } + o.on('--load-rawdata=FILE', 'input rawdata'){|r| + opt[:rawdata_input] = r + } o.on('-f', "--format=FORMAT", "output format (#{formats.keys.join(",")})", formats.keys){|r| opt[:format] = r } @@ -365,6 +387,14 @@ if __FILE__ == $0 parser.parse!(ARGV) opt[:output] ||= "bmlog-#{Time.now.strftime('%Y%m%d-%H%M%S')}.#{$$}#{formats[opt[:format]]}" - BenchmarkDriver.benchmark(opt) + + if input = opt[:rawdata_input] + b = open(input) {|f| + BenchmarkDriver.load(f, File.extname(input)[1..-1], opt) + } + b.show_results + else + BenchmarkDriver.benchmark(opt) + end end -- cgit v1.2.3