From ff3db7f05dcd584d56175ac267d848133a488ea0 Mon Sep 17 00:00:00 2001 From: Andrew Theurer Date: Thu, 23 Jul 2015 00:46:50 -0400 Subject: [PATCH] Fix where in fio-result.txt json parsing starts This fixes where in the fio-result.txt we start parsing json data. Fio puts non-json data in the beginning (boo!), so we have to avoid that stuff. Also, exit if the file happens to be empty. --- .../bench-scripts/postprocess/fio-postprocess | 26 ++++++++++++------- 1 file changed, 16 insertions(+), 10 deletions(-) diff --git a/agent/bench-scripts/postprocess/fio-postprocess b/agent/bench-scripts/postprocess/fio-postprocess index 6b30af7d10..8d0c3726fb 100755 --- a/agent/bench-scripts/postprocess/fio-postprocess +++ b/agent/bench-scripts/postprocess/fio-postprocess @@ -6,20 +6,26 @@ use JSON; my $dir = $ARGV[0]; my $iteration = $ARGV[1]; my $tool_group = $ARGV[2]; +my $js_str; open(JS, "<$dir/fio-result.txt"); # skip past the non json stuff while () { - if (/^{/) { + if (/{/) { last; } } -# read the rest of the file in to one string -local $/=undef; -binmode JS; -my $js_str = ; -$js_str = "{\n" . $js_str; +if ( eof JS ) { + print "Could not read rest of json data\n"; + exit 1; +} else { + # read the rest of the file in to one string + local $/=undef; + binmode JS; + $js_str = ; + $js_str = "{\n" . $js_str; +} # convert [json] string in to big hash my $fio_results; @@ -28,10 +34,10 @@ close(JS); my %results; my %all_job_results; my %all_client_results; -my $client_jobs; -my $job_name; -my $fio_json_field; -my $client_name; +my $client_jobs = ""; +my $job_name = ""; +my $fio_json_field = ""; +my $client_name = ""; if ( defined $$fio_results{"client_stats"} ) { # this is a multi-client test $fio_json_field = "client_stats";