Release GLib 2.35.1
[glib.git] / tests / run-assert-msg-test.sh
blobb6045d6b14806c8dc2b8b23d68011be2037a2974
1 #! /bin/sh
3 fail ()
5 echo "Test failed: $*"
6 exit 1
9 echo_v ()
11 if [ "$verbose" = "1" ]; then
12 echo "$*"
16 error_out=/dev/null
17 if [ "$1" = "-v" ]; then
18 verbose=1
19 error_out=/dev/stderr
20 fi
22 echo_v "Running assert-msg-test"
23 OUT=$(./assert-msg-test 2>&1) && fail "assert-msg-test should abort"
24 echo "$OUT" | grep -q '^ERROR:.*assert-msg-test.c:.*:.*main.*: assertion failed: (42 < 0)' || \
25 fail "does not print assertion message"
27 if ! type gdb >/dev/null 2>&1; then
28 echo_v "Skipped (no gdb installed)"
29 exit 0
32 msg_test="assert-msg-test"
33 if [ -e ".libs/lt-$msg_test" ]; then
34 msg_test="lt-$msg_test"
36 echo_v "Running gdb on assert-msg-test"
37 OUT=$(libtool --mode=execute gdb --batch --ex run --ex "set print elements 0" --ex "print (char*) __glib_assert_msg" .libs/$msg_test 2> $error_out) || \
38 fail "failed to run gdb"
40 echo_v "Checking if assert message is in __glib_assert_msg"
41 if ! echo "$OUT" | grep -q '^$1.*"ERROR:.*assert-msg-test.c:.*:.*main.*: assertion failed: (42 < 0)"'; then
42 fail "__glib_assert_msg does not have assertion message"
45 echo_v "All tests passed."