X-Git-Url: http://git.lttng.org./?a=blobdiff_plain;f=scripts%2Fbabeltrace%2Fbuild.sh;h=b6590a78b9323c358990d1468a2db8910c27d790;hb=e04f80ef6be68cf75ef15158c784f3232ce8145d;hp=58991010e7fd707c74950f89a0e9a90f0e4837c6;hpb=1183a11815822b173a33df994c0222597480f17c;p=lttng-ci.git diff --git a/scripts/babeltrace/build.sh b/scripts/babeltrace/build.sh index 5899101..b6590a7 100755 --- a/scripts/babeltrace/build.sh +++ b/scripts/babeltrace/build.sh @@ -1,7 +1,7 @@ #!/bin/bash -exu # -# Copyright (C) 2015 - Jonathan Rajotte-Julien -# 2016 - Michael Jeanson +# Copyright (C) 2015 Jonathan Rajotte-Julien +# 2016-2019 Michael Jeanson # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by @@ -80,7 +80,7 @@ SRCDIR="$WORKSPACE/src/babeltrace" TMPDIR="$WORKSPACE/tmp" PREFIX="$WORKSPACE/build" -# Create build and tmp directories +# Create install and tmp directories rm -rf "$PREFIX" "$TMPDIR" mkdir -p "$PREFIX" "$TMPDIR" @@ -161,6 +161,8 @@ sol10-i386) export CPPFLAGS="-I/opt/csw/include" export LDFLAGS="-L/opt/csw/lib -R/opt/csw/lib" export PKG_CONFIG_PATH="/opt/csw/lib/pkgconfig" + export PYTHON="python3" + export PYTHON_CONFIG="python3-config" ;; sol11-i386) export MAKE=gmake @@ -169,6 +171,8 @@ sol11-i386) export PATH="$PATH:/usr/perl5/bin" export LD_ALTEXEC=/usr/bin/gld export LD=/usr/bin/gld + export PYTHON="python3" + export PYTHON_CONFIG="python3-config" ;; macosx) export MAKE=make @@ -179,11 +183,15 @@ macosx) export PATH="/opt/local/bin:/opt/local/sbin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin" export CFLAGS="$CFLAGS -I/opt/local/include" export LDFLAGS="-L/opt/local/lib" + export PYTHON="python3" + export PYTHON_CONFIG="python3-config" ;; *) export MAKE=make export TAR=tar export NPROC=nproc + export PYTHON="python3" + export PYTHON_CONFIG="python3-config" ;; esac @@ -196,30 +204,58 @@ cd "$SRCDIR" # Get source version from configure script eval "$(grep '^PACKAGE_VERSION=' ./configure)" +# Enable dev mode by default for BT 2.0 builds +export BABELTRACE_DEBUG_MODE=1 +export BABELTRACE_DEV_MODE=1 +export BABELTRACE_MINIMAL_LOG_LEVEL=TRACE + # Set configure options for each build configuration -CONF_OPTS="" +CONF_OPTS=() case "$conf" in static) - echo "Static build" - CONF_OPTS="--enable-static --disable-shared" + echo "Static lib only configuration" + + CONF_OPTS+=("--enable-static" "--disable-shared") + if vergte "$PACKAGE_VERSION" "2.0"; then - CONF_OPTS="${CONF_OPTS} --enable-built-in-plugins" + CONF_OPTS+=("--enable-built-in-plugins") fi ;; + python-bindings) - echo "Build with python bindings" - # We only support bindings built with Python 3 - export PYTHON="python3" - export PYTHON_CONFIG="/usr/bin/python3-config" - CONF_OPTS="--enable-python-bindings" + echo "Python bindings configuration" + + CONF_OPTS+=("--enable-python-bindings") if vergte "$PACKAGE_VERSION" "2.0"; then - CONF_OPTS="${CONF_OPTS} --enable-python-bindings-doc --enable-python-plugins" + CONF_OPTS+=("--enable-python-bindings-doc" "--enable-python-plugins") fi ;; + +prod) + echo "Production configuration" + + # Unset the developper variables + unset BABELTRACE_DEBUG_MODE + unset BABELTRACE_DEV_MODE + unset BABELTRACE_MINIMAL_LOG_LEVEL + + # Enable the python bindings + CONF_OPTS+=("--enable-python-bindings" "--enable-python-bindings-doc" "--enable-python-plugins") + ;; + +min) + echo "Minimal configuration" + ;; + *) - echo "Standard build" - CONF_OPTS="" + echo "Standard configuration" + + # Enable the python bindings / plugins by default with babeltrace2, + # the test suite is mostly useless without it. + if vergte "$PACKAGE_VERSION" "2.0"; then + CONF_OPTS+=("--enable-python-bindings" "--enable-python-plugins") + fi ;; esac @@ -228,50 +264,84 @@ esac # dist: build via make dist # * : normal tree build # -# Make sure to move to the build_path and configure -# before continuing -BUILD_PATH="$SRCDIR" +# Make sure to move to the build dir and run configure +# before continuing. case "$build" in - oot) - echo "Out of tree build" - BUILD_PATH="$WORKSPACE/oot" - mkdir -p "$BUILD_PATH" - cd "$BUILD_PATH" - "$SRCDIR/configure" --prefix="$PREFIX" $CONF_OPTS - ;; - - dist) - echo "Distribution out of tree build" - BUILD_PATH="$(mktemp -d)" - - # Initial configure and generate tarball - "$SRCDIR/configure" - $MAKE dist - - mkdir -p "$BUILD_PATH" - cp ./*.tar.* "$BUILD_PATH/" - cd "$BUILD_PATH" - - # Ignore level 1 of tar - $TAR xvf ./*.tar.* --strip 1 - - "$BUILD_PATH/configure" --prefix="$PREFIX" $CONF_OPTS - ;; - - *) - echo "Standard in-tree build" - "$SRCDIR/configure" --prefix="$PREFIX" $CONF_OPTS - ;; +oot) + echo "Out of tree build" + + # Create and enter a temporary build directory + builddir=$(mktemp -d) + cd "$builddir" + + "$SRCDIR/configure" --prefix="$PREFIX" "${CONF_OPTS[@]}" + ;; + +dist) + echo "Distribution in-tree build" + + # Run configure and generate the tar file + # in the source directory + ./configure + $MAKE dist + + # Create and enter a temporary build directory + builddir=$(mktemp -d) + cd "$builddir" + + # Extract the distribution tar in the build directory, + # ignore the first directory level + $TAR xvf "$SRCDIR"/*.tar.* --strip 1 + + ./configure --prefix="$PREFIX" "${CONF_OPTS[@]}" + ;; + +oot-dist) + echo "Distribution out of tree build" + + # Create and enter a temporary build directory + builddir=$(mktemp -d) + cd "$builddir" + + # Run configure out of tree and generate the tar file + "$SRCDIR/configure" + $MAKE dist + + dist_srcdir="$(mktemp -d)" + cd "$dist_srcdir" + + # Extract the distribution tar in the new source directory, + # ignore the first directory level + $TAR xvf "$builddir"/*.tar.* --strip 1 + + # Create and enter a second temporary build directory + builddir="$(mktemp -d)" + cd "$builddir" + + # Run configure from the extracted distribution tar, + # out of the source tree + "$dist_srcdir/configure" --prefix="$PREFIX" "${CONF_OPTS[@]}" + ;; + +*) + echo "Standard in-tree build" + ./configure --prefix="$PREFIX" "${CONF_OPTS[@]}" + ;; esac +# We are now inside a configured build directory + # BUILD! $MAKE -j "$($NPROC)" V=1 $MAKE install -# Run tests +# Run tests, don't fail now, we want to run the archiving steps +set +e $MAKE --keep-going check +ret=$? +set -e -# Copy tap logs for the jenkins tap parser +# Copy tap logs for the jenkins tap parser before cleaning the build dir rsync -a --exclude 'test-suite.log' --include '*/' --include '*.log' --exclude='*' tests/ "$WORKSPACE/tap" # Clean the build directory @@ -287,7 +357,10 @@ find "$PREFIX/lib" -name "*.la" -exec rm -f {} \; # Clean temp dir for dist build if [ "$build" = "dist" ]; then cd "$SRCDIR" - rm -rf "$BUILD_PATH" + rm -rf "$builddir" fi +# Exit with the return code of the test suite +exit $ret + # EOF