fish-shell/tests/interactive.fish
2014-09-19 16:22:37 -07:00

55 lines
1.6 KiB
Fish

#!/usr/local/bin/fish
#
# Interactive tests using `expect`
function die
echo $argv[1] >&2
exit 1
end
for i in *.expect
rm -Rf tmp.interactive.config; or die "Couldn't remove tmp.interactive.config"
mkdir -p tmp.interactive.config/fish; or die "Couldn't create tmp.interactive.config/fish"
cp interactive.config tmp.interactive.config/fish/config.fish; or die "Couldn't create tmp.interactive.config/fish/config.fish"
begin
set -lx XDG_CONFIG_HOME $PWD/tmp.interactive.config
set -lx TERM dumb
expect -n -c 'source interactive.expect.rc' -f $i >$i.tmp.out ^$i.tmp.err
end
set -l tmp_status $status
set res ok
mv -f interactive.tmp.log $i.tmp.log
if not diff $i.tmp.out $i.out >/dev/null
set res fail
echo "Output differs for file $i. Diff follows:"
diff -u $i.tmp.out $i.out
end
if not diff $i.tmp.err $i.err >/dev/null
set res fail
echo "Error output differs for file $i. Diff follows:"
diff -u $i.tmp.err $i.err
end
set -l exp_status (cat $i.status)[1]
if test $tmp_status != $exp_status
set res fail
echo "Exit status differs for file $i."
echo "Expected $exp_status, got $tmp_status."
end
if test $res = ok
echo "File $i tested ok"
# clean up tmp files
rm -f $i.tmp.{err,out,log}
else
if set -qgx SHOW_INTERACTIVE_LOG
# dump the interactive log
# primarily for use in travis where we can't check it manually
echo "Log for file $i:"
cat $i.tmp.log
end
echo "File $i failed tests"
end
end