t / perf / bisect_run_scripton commit remote: convert get_ref_match to take a struct refspec (f3acb83)
   1#!/bin/sh
   2
   3script="$1"
   4test_number="$2"
   5info_dir="$3"
   6
   7# This aborts the bisection immediately
   8die () {
   9        echo >&2 "error: $*"
  10        exit 255
  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
  38if test $(echo "$newtime" "$rtime" "$oldtime" | awk '{ print ($1 - $2 > $2 - $3) }') = 1
  39then
  40        # Current commit is considered "good/old"
  41        echo "$rtime" >"$info_dir/oldtime"
  42        exit 0
  43else
  44        # Current commit is considered "bad/new"
  45        echo "$rtime" >"$info_dir/newtime"
  46        exit 1
  47fi