summaryrefslogtreecommitdiffstats
path: root/src/gl/tests/test-verify.sh
diff options
context:
space:
mode:
Diffstat (limited to '')
-rwxr-xr-xsrc/gl/tests/test-verify.sh25
1 files changed, 25 insertions, 0 deletions
diff --git a/src/gl/tests/test-verify.sh b/src/gl/tests/test-verify.sh
new file mode 100755
index 0000000..1e75d55
--- /dev/null
+++ b/src/gl/tests/test-verify.sh
@@ -0,0 +1,25 @@
+#!/bin/sh
+. "${srcdir=.}/init.sh"
+
+# We are not interested in triggering bugs in the compilers and tools
+# (such as gcc 4.3.1 on openSUSE 11.0).
+unset MALLOC_PERTURB_
+
+# Rather than figure out how to invoke the compiler with the right
+# include path ourselves, we let make do it:
+(cd "$initial_cwd_" \
+ && rm -f test-verify-try.o \
+ && $MAKE test-verify-try.o >/dev/null 2>&1) \
+ || skip_ "cannot compile error-free"
+
+# Now, prove that we encounter all expected compilation failures:
+: >out
+: >err
+for i in 1 2 3 4 5; do
+ (cd "$initial_cwd_"
+ rm -f test-verify-try.o
+ $MAKE CFLAGS=-DEXP_FAIL=$i test-verify-try.o) >>out 2>>err \
+ && { warn_ "compiler didn't detect verification failure $i"; fail=1; }
+done
+
+Exit $fail