Branch
Hash :
07b232f1
Author :
Date :
2025-04-14T22:49:55
c-stack tests: Remove left-over core dump file. Suggested by Eric Blake in <https://lists.gnu.org/archive/html/bug-gnulib/2025-04/msg00101.html>. * tests/test-c-stack2.sh: Remove 'core' and 'test-c-stack.core' when done.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
#!/bin/sh
tmpfiles=""
trap 'rm -fr $tmpfiles' HUP INT QUIT TERM
tmpfiles="t-c-stack2.tmp"
# Prepare to clean up a core dump file, assuming the most common naming
# conventions for such files. (Core dump file names may be customized
# through /proc/sys/kernel/core_pattern or 'coredumpctl'.)
tmpfiles="$tmpfiles core test-c-stack.core"
# Sanitize exit status within a subshell, since some shells fail to
# redirect stderr on their message about death due to signal.
(${CHECKER} ./test-c-stack${EXEEXT} 1; exit $?) 2> t-c-stack2.tmp
case $? in
77) if grep 'stack overflow' t-c-stack2.tmp >/dev/null ; then
if test -z "$LIBSIGSEGV"; then
echo 'cannot tell stack overflow from crash; consider installing libsigsegv' >&2
exit 77
else
echo 'cannot tell stack overflow from crash, in spite of libsigsegv' >&2
exit 1
fi
else
cat t-c-stack2.tmp >&2
exit 77
fi
;;
1)
# Dereferencing NULL exits the program with status 1,
# so this test doesn't check the c-stack testing harness like it should.
# https://lists.gnu.org/r/grep-devel/2020-09/msg00034.html
cat t-c-stack2.tmp >&2
echo 'skipping test (perhaps gcc -fsanitize=undefined is in use?)'
exit 77;;
0) (exit 1); exit 1 ;;
esac
if grep 'program error' t-c-stack2.tmp >/dev/null ; then
:
else
(exit 1); exit 1
fi
rm -fr $tmpfiles
exit 0