Refactor test run script

This commit is contained in:
Maxime Coste 2017-02-21 23:26:39 +00:00
parent 186eed0906
commit d0d38da3c5

211
test/run
View File

@ -1,163 +1,136 @@
#!/bin/sh #!/bin/sh
# Color codes ├──────────────────────────────────────────────────────────────────
none="00"; red="31"; green="32"; yellow="33"; magenta="35"; bold="01"
# Main ├──────────────────────────────────────────────────────────────────────── # Main ├────────────────────────────────────────────────────────────────────────
main() { main() {
number_tests=0 kak_commands='
number_failures=0
dirs="${@:-.}"
test=$(pwd)
tmpdir="${TMPDIR:-/tmp}"
work=$(mktemp -d ${tmpdir}/kak-tests.XXXXXXXX)
trap "rm -R $work" EXIT
for dir in $(find $dirs -type d | sort); do
cd $test/$dir;
test_files=$(ls out selections state display 2>/dev/null)
mkdir -p $work/$dir
for file in $(ls in cmd rc 2>/dev/null); do
cp $file $work/$dir/
done
cd $work/$dir;
indent="$(echo "${dir}/" | sed -e 's|[^/]*/\+| |g')"
name=$(basename $PWD)
should_fail=$(test ! -e error; echo $?)
if ! test -e cmd; then
echo "$indent$name"
elif test -x enabled && ! ./enabled; then
echo "$indent$name (disabled)" | colorize yellow normal
else
number_tests=$(($number_tests + 1))
touch in; cp in out
kak_commands="
set global autoreload yes set global autoreload yes
set global autoinfo '' set global autoinfo ""
set global autoshowcompl false set global autoshowcompl false
try %{ source rc } try %{ source rc }
try %{ try %{
exec -save-regs '/' '%s%\(\K[^)]+<ret><c-s>ld<a-t>(hHdi<c-u><esc><c-o>' exec -save-regs / %{%s%\(\K[^)]+<ret><c-s>ld<a-t>(hHdi<c-u><esc><c-o>}
} catch %{ exec gg } } catch %{ exec gg }
hook global RuntimeError .+ %{ hook global RuntimeError .+ %{
echo -debug -- error: %val{hook_param} echo -debug -- error: %val{hook_param}
eval -buffer *debug* write debug eval -buffer *debug* write debug
quit! quit!
} }
exec '$(cat cmd | sed -e s/\'/\\\\\'/g)' exec "%sh{cat cmd}"
exec <c-l> exec <c-l>
eval -buffer *debug* write debug eval -buffer *debug* write debug
nop %sh{ nop %sh{
IFS== printf %s\\n "$kak_selections" > selections
printf '%s\\n' \"\$kak_selections\" > selections printf %s\\n "$kak_selections_desc" > state
printf '%s\\n' \"\$kak_selections_desc\" > state
} }
write out write out
quit! quit!
" '
session="kak-tests"
rm -f ${tmpdir}/kakoune/$USER/$session
${test}/../src/kak out -n -s "$session" -ui json -e "$kak_commands" > display
retval=$?
if [ $should_fail -eq 0 ]; then
if [ $retval -ne 0 ]; then
echo "Kakoune returned error $retval"
number_failures=$(($number_failures + 1))
echo "$indent$name" | colorize red normal
else
failed=no
for expect in $test_files; do
if ! cmp -s $test/$dir/$expect $expect; then
if [ "$failed" = no ]; then
echo "$indent$name" | colorize red normal
failed=yes
fi
echo
show_diff $test/$dir/$expect $expect
fi
done
if [ "$failed" = no ]; then
echo "$indent$name" | colorize green normal
else
number_failures=$(($number_failures + 1))
echo
if test -e debug; then
echo "debug buffer:" | colorize yellow normal
cat debug
echo
fi
fi
fi
else
failed=no
if [ ! -e stderr ]; then
if [ $retval -eq 0 ]; then
echo "$indent$name" | colorize red normal
number_failures=$(($number_failures + 1))
failed=yes
fi
else
sed -i -e 's/^[0-9]*:[0-9]*: //g' stderr
if [ -s error ] && ! cmp -s error stderr; then
echo "$indent$name" | colorize yellow normal
show_diff error stderr
failed=yes
fi
fi
if [ "$failed" = no ]; then root=$PWD
echo "$indent$name" | colorize green normal tmpdir="${TMPDIR:-/tmp}"
work=$(mktemp -d $tmpdir/kak-tests.XXXXXXXX)
trap "rm -R $work" EXIT
number_tests=0
number_failures=0
for dir in $(find "${@:-.}" -type d | sort); do
cd $root/$dir;
mkdir -p $work/$dir
for file in in cmd rc; do
[ -e $file ] && cp $file $work/$dir/
done
cd $work/$dir;
indent="$(echo "$dir/" | sed -e 's|[^/]*/\+| |g')"
name=${PWD##*/}
if [ ! -e cmd ]; then
echo "$indent$name"
continue
elif [ -x enabled ] && ! ./enabled; then
echo "$indent$name (disabled)" | colorize $yellow $none
continue
fi
number_tests=$(($number_tests + 1))
touch in; cp in out
session="kak-tests"
rm -f $tmpdir/kakoune/$USER/$session
$root/../src/kak out -n -s "$session" -ui json -e "$kak_commands" > display
retval=$?
failed=0
if [ ! -e error ]; then # failure not expected
if [ $retval -ne 0 ]; then
echo "$indent$name" | colorize $red $none
echo "$indent Kakoune returned error $retval"
failed=1
else
for file in out selections state display; do
if [ -e $root/$dir/$file ] && ! cmp -s $root/$dir/$file $file; then
if [ $failed -eq 0 ]; then
echo "$indent$name" | colorize $red $none
failed=1
fi
show_diff $root/$dir/$file $file
fi
done
if [ $failed -ne 0 ] && [ -e debug ]; then
printf "\ndebug buffer:\n" | colorize $yellow $none
cat debug
fi fi
fi fi
else # failure expected
if [ -e stderr ]; then
sed -i -e 's/^[0-9]*:[0-9]*: //g' stderr
if [ -s error ] && ! cmp -s error stderr; then
echo "$indent$name" | colorize $yellow $none
show_diff error stderr
failed=1
fi
elif [ $retval -eq 0 ]; then
echo "$indent$name" | colorize $red $none
echo "$indent Expected failure, but Kakoune returned 0"
failed=1
fi
fi
if [ $failed -eq 0 ]; then
echo "$indent$name" | colorize $green $none
else
number_failures=$(($number_failures + 1))
fi fi
done done
if expr $number_failures > 0; then
color=red if [ $number_failures -gt 0 ]; then
color=$red
else else
color=green color=$green
fi fi
echo printf "\nResume: %s tests, %s failures\n" $number_tests $number_failures | colorize $color $none
echo Resume:
echo $number_tests tests, $number_failures failures | colorize $color normal
exit $number_failures exit $number_failures
} }
# Utility ├───────────────────────────────────────────────────────────────────── # Utility ├─────────────────────────────────────────────────────────────────────
get_ansi_code() {
color_name=${1:-none}
style_name=${2:-none}
case "$color_name" in
none) color_nr=00 ;;
red) color_nr=31 ;;
green) color_nr=32 ;;
yellow) color_nr=33 ;;
magenta) color_nr=35 ;;
*) color_nr=00 ;;
esac
case "$style_name" in
none) style_nr=00 ;;
bold) style_nr=01 ;;
*) style_nr=00 ;;
esac
printf '\033[%s;%sm' $style_nr $color_nr
}
colorize() { colorize() {
text=$(cat) color=${1:-$none}
color_name=${1:-none} style=${2:-$none}
style_name=${2:-none} printf '\033[%s;%sm%s\033[00;00m\n' $style $color "$(cat)"
printf '%s\n' "$(get_ansi_code $color_name $style_name)$text$(get_ansi_code none none)"
} }
show_diff() { show_diff() {
diff -u $1 $2 | while IFS='' read -r line; do diff -u $1 $2 | while IFS='' read -r line; do
first_character=$(printf '%s\n' "$line" | cut -b 1) first_character=$(printf '%s\n' "$line" | cut -b 1)
case $first_character in case $first_character in
+) color=green ;; +) color=$green ;;
-) color=red ;; -) color=$red ;;
@) color=magenta ;; @) color=$magenta ;;
*) color=none ;; *) color=$none ;;
esac esac
printf '%s\n' "$line" | colorize $color normal printf '%s\n' "$line" | colorize $color $none
done done
} }
main $@ main "$@"