git.shiar.nl
/
barcat.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
t: colorize results on tty output
[barcat.git]
/
t
/
regress.t
diff --git
a/t/regress.t
b/t/regress.t
index 45ee5ba2b64d56682f78719e1520bfbe7943da50..b8d05ddcc8a3170072dd2681c3ec99fadf6647d4 100755
(executable)
--- a/
t/regress.t
+++ b/
t/regress.t
@@
-3,12
+3,19
@@
cd "${0%/*}" || exit 1
test_count=0
cd "${0%/*}" || exit 1
test_count=0
+fail_count=0
COLUMNS=40
COLUMNS=40
+colorize=
+test -t 1 && colorize=1
+color () {
+ test -n "$colorize" &&
+ printf '\e[%sm' $@
+}
regenerate=
diffcmd () {
comm --nocheck-order --output-delimiter=::: -3 $@ |
regenerate=
diffcmd () {
comm --nocheck-order --output-delimiter=::: -3 $@ |
- perl -pe
'END{exit !!$.} s/^:::/>/ || s/^/</'
+ perl -pe
"END{exit !!\$.} s/^:::/$(color 31)>/ || s/^/$(color 32)</"
}
for option in "$@"
}
for option in "$@"
@@
-42,8
+49,27
@@
do
if test -e $file.out; then $cmd 2>&1 | diffcmd "$file.out" -; fi
fi
if test -e $file.out; then $cmd 2>&1 | diffcmd "$file.out" -; fi
fi
- test 0 = $? || printf 'not '
+ if test 0 != $?
+ then
+ fail_count=$((fail_count+1))
+ color 1\;31
+ printf 'not '
+ fi
echo "ok $test_count - $name"
echo "ok $test_count - $name"
+ color 0
done
done
+if test $fail_count = 0
+then
+ color 32
+ echo "# passed all $test_count test(s)"
+else
+ color 31
+ echo "# failed $fail_count among $test_count test(s)"
+ fail_count=1 # exit code
+fi
+
+color 0\;36
echo "1..$test_count"
echo "1..$test_count"
+color 0
+exit $fail_count