#!/bin/sh # Build script for Travis CI if test -z $TRAVIS_BUILD_DIR; then TRAVIS_BUILD_DIR=$PWD fi cd $TRAVIS_BUILD_DIR TARGET=check DEPS="libgmp-dev" CFLAGS="-g -O2 -Wall -Wno-format -Wno-format-security -Wno-pointer-sign -Werror" case "$TEST" in default) # should be the default, but lets make sure CONFIG="--with-printf-hooks=glibc" ;; openssl) CONFIG="--disable-defaults --enable-pki --enable-openssl" DEPS="libssl-dev" ;; gcrypt) CONFIG="--disable-defaults --enable-pki --enable-gcrypt --enable-pkcs1" DEPS="libgcrypt11-dev" ;; printf-builtin) CONFIG="--with-printf-hooks=builtin" ;; all|coverage) CONFIG="--enable-all --disable-android-dns --disable-android-log --disable-dumm --disable-kernel-pfroute --disable-keychain --disable-lock-profiler --disable-padlock --disable-fuzzing --disable-osx-attr --disable-tkm --disable-uci --disable-systemd --disable-soup --disable-unwind-backtraces --disable-svc --disable-dbghelp-backtraces --disable-socket-win --disable-kernel-wfp --disable-kernel-iph --disable-winhttp" # Ubuntu 14.04 does provide a too old libtss2-dev CONFIG="$CONFIG --disable-tss-tss2" # not enabled on the build server CONFIG="$CONFIG --disable-af-alg" if test "$TEST" != "coverage"; then CONFIG="$CONFIG --disable-coverage" else # not actually required but configure checks for it DEPS="$DEPS lcov" fi DEPS="$DEPS libcurl4-gnutls-dev libsoup2.4-dev libunbound-dev libldns-dev libmysqlclient-dev libsqlite3-dev clearsilver-dev libfcgi-dev libnm-glib-dev libnm-glib-vpn-dev libpcsclite-dev libpam0g-dev binutils-dev libunwind8-dev libjson0-dev iptables-dev python-pip libtspi-dev" PYDEPS="pytest" ;; win*) CONFIG="--disable-defaults --enable-svc --enable-ikev2 --enable-ikev1 --enable-static --enable-test-vectors --enable-nonce --enable-constraints --enable-revocation --enable-pem --enable-pkcs1 --enable-pkcs8 --enable-x509 --enable-pubkey --enable-acert --enable-eap-tnc --enable-eap-ttls --enable-eap-identity --enable-updown --enable-ext-auth --enable-libipsec --enable-tnccs-20 --enable-imc-attestation --enable-imv-attestation --enable-imc-os --enable-imv-os --enable-tnc-imv --enable-tnc-imc --enable-pki --enable-swanctl --enable-socket-win" # no make check for Windows binaries unless we run on a windows host if test "$APPVEYOR" != "True"; then TARGET= else CONFIG="$CONFIG --enable-openssl" CFLAGS="$CFLAGS -I/c/OpenSSL-$TEST/include" LDFLAGS="-L/c/OpenSSL-$TEST" export LDFLAGS fi CFLAGS="$CFLAGS -mno-ms-bitfields" DEPS="gcc-mingw-w64-base" case "$TEST" in win64) # headers on 12.04 are too old, so we only build the plugins here CONFIG="--host=x86_64-w64-mingw32 $CONFIG --enable-dbghelp-backtraces --enable-kernel-iph --enable-kernel-wfp --enable-winhttp" DEPS="gcc-mingw-w64-x86-64 binutils-mingw-w64-x86-64 mingw-w64-x86-64-dev $DEPS" CC="x86_64-w64-mingw32-gcc" # apply patch to MinGW headers if test "$APPVEYOR" != "True" -a -z "$1"; then sudo patch -f -p 4 -d /usr/share/mingw-w64/include < src/libcharon/plugins/kernel_wfp/mingw-w64-4.8.1.diff fi ;; win32) CONFIG="--host=i686-w64-mingw32 $CONFIG" # currently only works on 12.04, so use mingw-w64-dev instead of mingw-w64-i686-dev DEPS="gcc-mingw-w64-i686 binutils-mingw-w64-i686 mingw-w64-dev $DEPS" CC="i686-w64-mingw32-gcc" ;; esac ;; osx) # use the same options as in the Homebrew Formula CONFIG="--disable-defaults --enable-charon --enable-cmd --enable-constraints --enable-curl --enable-eap-gtc --enable-eap-identity --enable-eap-md5 --enable-eap-mschapv2 --enable-ikev1 --enable-ikev2 --enable-kernel-libipsec --enable-kernel-pfkey --enable-kernel-pfroute --enable-nonce --enable-openssl --enable-osx-attr --enable-pem --enable-pgp --enable-pkcs1 --enable-pkcs8 --enable-pki --enable-pubkey --enable-revocation --enable-scepclient --enable-socket-default --enable-sshkey --enable-stroke --enable-swanctl --enable-unity --enable-updown --enable-x509 --enable-xauth-generic" DEPS="bison gettext openssl curl" BREW_PREFIX=$(brew --prefix) export PATH=$BREW_PREFIX/opt/bison/bin:$PATH export ACLOCAL_PATH=$BREW_PREFIX/opt/gettext/share/aclocal:$ACLOCAL_PATH for pkg in openssl curl do PKG_CONFIG_PATH=$BREW_PREFIX/opt/$pkg/lib/pkgconfig:$PKG_CONFIG_PATH CPPFLAGS="-I$BREW_PREFIX/opt/$pkg/include $CPPFLAGS" LDFLAGS="-L$BREW_PREFIX/opt/$pkg/lib $LDFLAGS" done export PKG_CONFIG_PATH export CPPFLAGS export LDFLAGS ;; fuzzing) CFLAGS="$CFLAGS -DNO_CHECK_MEMWIPE" CONFIG="--enable-fuzzing --enable-static --disable-shared --disable-scripts" # don't run any of the unit tests export TESTS_RUNNERS= # prepare corpora if test -z "$1"; then if test -z "$FUZZING_CORPORA"; then git clone --depth 1 https://github.com/strongswan/fuzzing-corpora.git fuzzing-corpora export FUZZING_CORPORA=$TRAVIS_BUILD_DIR/fuzzing-corpora fi # these are about the same as those on OSS-Fuzz (except for the # symbolize options and strip_path_prefix) export ASAN_OPTIONS=redzone=16:handle_sigill=1:strict_string_check=1:\ allocator_release_to_os_interval_ms=500:strict_memcmp=1:detect_container_overflow=1:\ coverage=0:allocator_may_return_null=1:use_sigaltstack=1:detect_stack_use_after_return=1:\ alloc_dealloc_mismatch=0:detect_leaks=1:print_scariness=1:max_uar_stack_size_log=16:\ handle_abort=1:check_malloc_usable_size=0:quarantine_size_mb=10:detect_odr_violation=0:\ symbolize=1:handle_segv=1:fast_unwind_on_fatal=0:external_symbolizer_path=/usr/bin/llvm-symbolizer-3.5 fi ;; dist) TARGET=distcheck ;; apidoc) DEPS="doxygen" CONFIG="--disable-defaults" TARGET=apidoc ;; *) echo "$0: unknown test $TEST" >&2 exit 1 ;; esac if test "$1" = "deps"; then case "$TRAVIS_OS_NAME" in linux) sudo apt-get update -qq && \ sudo apt-get install -qq bison flex gperf gettext $DEPS ;; osx) brew update && \ # workaround for issue #6352 brew uninstall --force libtool && brew install libtool && \ brew install $DEPS ;; esac exit $? fi if test "$1" = "pydeps"; then test -z "$PYDEPS" || sudo pip -q install $PYDEPS exit $? fi CONFIG="$CONFIG --disable-dependency-tracking --enable-silent-rules --enable-test-vectors --enable-monolithic=${MONOLITHIC-no} --enable-leak-detective=${LEAK_DETECTIVE-no}" echo "$ ./autogen.sh" ./autogen.sh || exit $? echo "$ CC=$CC CFLAGS=\"$CFLAGS\" ./configure $CONFIG" CC="$CC" CFLAGS="$CFLAGS" ./configure $CONFIG || exit $? case "$TEST" in apidoc) exec 2>make.warnings ;; *) ;; esac echo "$ make $TARGET" make -j4 $TARGET || exit $? case "$TEST" in apidoc) if test -s make.warnings; then cat make.warnings exit 1 fi ;; *) ;; esac