| #!/bin/sh |
| |
| script="$1" |
| test_number="$2" |
| info_dir="$3" |
| |
| # This aborts the bisection immediately |
| die () { |
| echo >&2 "error: $*" |
| exit 255 |
| } |
| |
| bisect_head=$(git rev-parse --verify BISECT_HEAD) || die "Failed to find BISECT_HEAD ref" |
| |
| script_number=$(echo "$script" | sed -e "s/^p\([0-9]*\).*\$/\1/") || die "Failed to get script number for '$script'" |
| |
| oldtime=$(cat "$info_dir/oldtime") || die "Failed to access '$info_dir/oldtime'" |
| newtime=$(cat "$info_dir/newtime") || die "Failed to access '$info_dir/newtime'" |
| |
| cd t/perf || die "Failed to cd into 't/perf'" |
| |
| result_file="$info_dir/perf_${script_number}_${bisect_head}_results.txt" |
| |
| GIT_PERF_DIRS_OR_REVS="$bisect_head" |
| export GIT_PERF_DIRS_OR_REVS |
| |
| # Don't use codespeed |
| GIT_PERF_CODESPEED_OUTPUT= |
| GIT_PERF_SEND_TO_CODESPEED= |
| export GIT_PERF_CODESPEED_OUTPUT |
| export GIT_PERF_SEND_TO_CODESPEED |
| |
| ./run "$script" >"$result_file" 2>&1 || die "Failed to run perf test '$script'" |
| |
| rtime=$(sed -n "s/^$script_number\.$test_number:.*\([0-9]\+\.[0-9]\+\)(.*).*\$/\1/p" "$result_file") |
| |
| echo "newtime: $newtime" |
| echo "rtime: $rtime" |
| echo "oldtime: $oldtime" |
| |
| # Compare ($newtime - $rtime) with ($rtime - $oldtime) |
| # Times are decimal number, not integers |
| |
| if test $(echo "$newtime" "$rtime" "$oldtime" | awk '{ print ($1 - $2 > $2 - $3) }') = 1 |
| then |
| # Current commit is considered "good/old" |
| echo "$rtime" >"$info_dir/oldtime" |
| exit 0 |
| else |
| # Current commit is considered "bad/new" |
| echo "$rtime" >"$info_dir/newtime" |
| exit 1 |
| fi |