1#!/bin/sh 2 3script="$1" 4test_number="$2" 5info_dir="$3" 6 7# This aborts the bisection immediately 8die () { 9echo>&2"error: $*" 10exit255 11} 12 13bisect_head=$(git rev-parse --verify BISECT_HEAD) || die "Failed to find BISECT_HEAD ref" 14 15script_number=$(echo"$script"|sed-e"s/^p\([0-9]*\).*\$/\1/") || die "Failed to get script number for '$script'" 16 17oldtime=$(cat"$info_dir/oldtime") || die "Failed to access '$info_dir/oldtime'" 18newtime=$(cat"$info_dir/newtime") || die "Failed to access '$info_dir/newtime'" 19 20cd t/perf || die "Failed to cd into 't/perf'" 21 22result_file="$info_dir/perf_${script_number}_${bisect_head}_results.txt" 23 24GIT_PERF_DIRS_OR_REVS="$bisect_head" 25export GIT_PERF_DIRS_OR_REVS 26 27./run "$script">"$result_file"2>&1|| die "Failed to run perf test '$script'" 28 29rtime=$(sed-n"s/^$script_number\.$test_number:.*\([0-9]\+\.[0-9]\+\)(.*).*\$/\1/p""$result_file") 30 31echo"newtime:$newtime" 32echo"rtime:$rtime" 33echo"oldtime:$oldtime" 34 35# Compare ($newtime - $rtime) with ($rtime - $oldtime) 36# Times are decimal number, not integers 37 38iftest $(echo"$newtime""$rtime""$oldtime"|awk'{ print ($1-$2>$2-$3) }') =1 39then 40# Current commit is considered "good/old" 41echo"$rtime">"$info_dir/oldtime" 42exit0 43else 44# Current commit is considered "bad/new" 45echo"$rtime">"$info_dir/newtime" 46exit1 47fi