travis: Disable unwind backtraces regardless of LEAK_DETECTIVE option
[strongswan.git] / scripts / test.sh
1 #!/bin/sh
2 # Build script for Travis CI
3
4 if test -z $TRAVIS_BUILD_DIR; then
5 TRAVIS_BUILD_DIR=$PWD
6 fi
7
8 cd $TRAVIS_BUILD_DIR
9
10 TARGET=check
11
12 DEPS="libgmp-dev"
13
14 CFLAGS="-g -O2 -Wall -Wno-format -Wno-format-security -Wno-pointer-sign -Werror"
15
16 case "$TEST" in
17 default)
18 # should be the default, but lets make sure
19 CONFIG="--with-printf-hooks=glibc"
20 ;;
21 openssl)
22 CONFIG="--disable-defaults --enable-pki --enable-openssl"
23 DEPS="libssl-dev"
24 ;;
25 gcrypt)
26 CONFIG="--disable-defaults --enable-pki --enable-gcrypt --enable-pkcs1"
27 DEPS="libgcrypt11-dev"
28 ;;
29 printf-builtin)
30 CONFIG="--with-printf-hooks=builtin"
31 ;;
32 all)
33 CONFIG="--enable-all --disable-android-dns --disable-android-log
34 --disable-dumm --disable-kernel-pfroute --disable-keychain
35 --disable-lock-profiler --disable-maemo --disable-padlock
36 --disable-osx-attr --disable-tkm --disable-uci --disable-aikgen
37 --disable-systemd --disable-soup --disable-unwind-backtraces
38 --disable-svc --disable-dbghelp-backtraces --disable-socket-win
39 --disable-kernel-wfp --disable-kernel-iph --disable-winhttp"
40 if test "$LEAK_DETECTIVE" = "yes"; then
41 # libgcrypt can't be deinitialized
42 CONFIG="$CONFIG --disable-gcrypt"
43 fi
44 if test "$MONOLITHIC" = "yes"; then
45 # Ubuntu 12.04 does not provide a proper -liptc pkg-config
46 CONFIG="$CONFIG --disable-forecast --disable-connmark"
47 fi
48 # not enabled on the build server
49 CONFIG="$CONFIG --disable-af-alg"
50 # TODO: enable? perhaps via coveralls.io (cpp-coveralls)?
51 CONFIG="$CONFIG --disable-coverage"
52 DEPS="$DEPS libcurl4-gnutls-dev libsoup2.4-dev libunbound-dev libldns-dev
53 libmysqlclient-dev libsqlite3-dev clearsilver-dev libfcgi-dev
54 libnm-glib-dev libnm-glib-vpn-dev libpcsclite-dev libpam0g-dev
55 binutils-dev libunwind7-dev libjson0-dev iptables-dev"
56 ;;
57 win*)
58 CONFIG="--disable-defaults --enable-svc --enable-ikev2
59 --enable-ikev1 --enable-static --enable-test-vectors --enable-nonce
60 --enable-constraints --enable-revocation --enable-pem --enable-pkcs1
61 --enable-pkcs8 --enable-x509 --enable-pubkey --enable-acert
62 --enable-eap-tnc --enable-eap-ttls --enable-eap-identity
63 --enable-updown --enable-ext-auth
64 --enable-tnccs-20 --enable-imc-attestation --enable-imv-attestation
65 --enable-imc-os --enable-imv-os --enable-tnc-imv --enable-tnc-imc
66 --enable-pki --enable-swanctl --enable-socket-win"
67 # no make check for Windows binaries
68 TARGET=
69 CFLAGS="$CFLAGS -mno-ms-bitfields"
70 DEPS="gcc-mingw-w64-base mingw-w64-dev"
71 case "$TEST" in
72 win64)
73 CONFIG="--host=x86_64-w64-mingw32 $CONFIG"
74 DEPS="gcc-mingw-w64-x86-64 binutils-mingw-w64-x86-64 $DEPS"
75 CC="x86_64-w64-mingw32-gcc"
76 ;;
77 win32)
78 CONFIG="--host=i686-w64-mingw32 $CONFIG"
79 DEPS="gcc-mingw-w64-i686 binutils-mingw-w64-i686 $DEPS"
80 CC="i686-w64-mingw32-gcc"
81 ;;
82 esac
83 ;;
84 dist)
85 TARGET=distcheck
86 ;;
87 *)
88 echo "$0: unknown test $TEST" >&2
89 exit 1
90 ;;
91 esac
92
93 if test "$1" = "deps"; then
94 sudo apt-get install -qq $DEPS
95 exit $?
96 fi
97
98 CONFIG="$CONFIG
99 --enable-silent-rules
100 --enable-test-vectors
101 --enable-monolithic=${MONOLITHIC-no}
102 --enable-leak-detective=${LEAK_DETECTIVE-no}"
103
104 echo "$ CC="$CC" CFLAGS="$CFLAGS" ./configure $CONFIG && make $TARGET"
105 CC="$CC" CFLAGS="$CFLAGS" ./configure $CONFIG && make -j4 $TARGET