X-Git-Url: http://git.lttng.org./?a=blobdiff_plain;f=scripts%2Flibrseq%2Fbuild.sh;h=d56a399fcdbe9869c88c971b44e24de5ff014c8e;hb=32dde2a3e67e7c517fe2699b3f24781b4a48ae59;hp=e8a9863a313f140199bbfc2346a3db781107e14a;hpb=ae855ba141f3a5e8236c709e40e2b7b4673f4609;p=lttng-ci.git diff --git a/scripts/librseq/build.sh b/scripts/librseq/build.sh index e8a9863..d56a399 100755 --- a/scripts/librseq/build.sh +++ b/scripts/librseq/build.sh @@ -1,7 +1,7 @@ -#!/bin/bash -exu +#!/bin/bash # # Copyright (C) 2015 Jonathan Rajotte-Julien -# Copyright (C) 2019 Michael Jeanson +# Copyright (C) 2019-2020 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 @@ -16,6 +16,8 @@ # You should have received a copy of the GNU General Public License # along with this program. If not, see . +set -exu + # Version compare functions vercomp () { set +u @@ -69,8 +71,20 @@ verne() { [ "$res" -ne "0" ] } -# Required parameters -arch=${arch:-} +failed_configure() { + # Assume we are in the configured build directory + echo "#################### BEGIN config.log ####################" + cat config.log + echo "#################### END config.log ####################" + + # End the build with failure + exit 1 +} + +# Required variables +WORKSPACE=${WORKSPACE:-} + +platform=${platform:-} conf=${conf:-} build=${build:-} cc=${cc:-} @@ -78,14 +92,17 @@ cc=${cc:-} SRCDIR="$WORKSPACE/src/librseq" TMPDIR="$WORKSPACE/tmp" -PREFIX="$WORKSPACE/build" +PREFIX="/build" -# Create build and tmp directories -rm -rf "$PREFIX" "$TMPDIR" -mkdir -p "$PREFIX" "$TMPDIR" +# Create tmp directory +rm -rf "$TMPDIR" +mkdir -p "$TMPDIR" export TMPDIR export CFLAGS="-g -O2" + +# Add the convenience headers in extra to the +# include path. export CPPFLAGS="-I$SRCDIR/extra" # Set compiler variables @@ -94,49 +111,17 @@ gcc) export CC=gcc export CXX=g++ ;; -gcc-4.8) - export CC=gcc-4.8 - export CXX=g++-4.8 - ;; -gcc-5) - export CC=gcc-5 - export CXX=g++-5 - ;; -gcc-6) - export CC=gcc-6 - export CXX=g++-6 - ;; -gcc-7) - export CC=gcc-7 - export CXX=g++-7 - ;; -gcc-8) - export CC=gcc-8 - export CXX=g++-8 +gcc-*) + export CC=gcc-${cc#gcc-} + export CXX=g++-${cc#gcc-} ;; clang) export CC=clang export CXX=clang++ ;; -clang-3.9) - export CC=clang-3.9 - export CXX=clang++-3.9 - ;; -clang-4.0) - export CC=clang-4.0 - export CXX=clang++-4.0 - ;; -clang-5.0) - export CC=clang-5.0 - export CXX=clang++-5.0 - ;; -clang-6.0) - export CC=clang-6.0 - export CXX=clang++-6.0 - ;; -clang-7) - export CC=clang-7 - export CXX=clang++-7 +clang-*) + export CC=clang-${cc#clang-} + export CXX=clang++-${cc#clang-} ;; *) if [ "x$cc" != "x" ]; then @@ -145,15 +130,26 @@ clang-7) ;; esac +if [ "x${CC:-}" != "x" ]; then + echo "Selected compiler:" + "$CC" -v +fi + # Set platform variables -case "$arch" in +case "$platform" in *) export MAKE=make export TAR=tar export NPROC=nproc + export PYTHON="python3" + export PYTHON_CONFIG="python3-config" ;; esac +# Print build env details +print_os || true +print_tooling || true + # Enter the source directory cd "$SRCDIR" @@ -162,85 +158,124 @@ cd "$SRCDIR" # Get source version from configure script eval "$(grep '^PACKAGE_VERSION=' ./configure)" +PACKAGE_VERSION=${PACKAGE_VERSION//\-pre*/} -TARBALL_FILE="librseq-$PACKAGE_VERSION.tar.bz2" # Set configure options and environment variables for each build # configuration. -CONF_OPTS="" +CONF_OPTS=("--prefix=$PREFIX") case "$conf" in static) - echo "Static build" - CONF_OPTS="--enable-static --disable-shared" + echo "Static lib only configuration" + + CONF_OPTS+=("--enable-static" "--disable-shared") ;; *) - echo "Standard build" - CONF_OPTS="" + echo "Standard configuration" ;; esac # Build type -# oot : out-of-tree build -# dist: build via make dist -# * : normal tree build +# oot : out-of-tree build +# dist : build via make dist +# oot-dist: build via make dist out-of-tree +# * : 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 directory 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 + + # Create and enter a temporary build directory + builddir=$(mktemp -d) + cd "$builddir" + + "$SRCDIR/configure" "${CONF_OPTS[@]}" || failed_configure ;; dist) + echo "Distribution in-tree build" + + # Run configure and generate the tar file + # in the source directory + ./configure || failed_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 + + # Build in extracted source tree + ./configure "${CONF_OPTS[@]}" || failed_configure + ;; + +oot-dist) echo "Distribution out of tree build" - BUILD_PATH=$(mktemp -d) - # Initial configure and generate tarball - "$SRCDIR/configure" + # Create and enter a temporary build directory + builddir=$(mktemp -d) + cd "$builddir" + + # Run configure out of tree and generate the tar file + "$SRCDIR/configure" || failed_configure $MAKE dist - mkdir -p "$BUILD_PATH" - cp "./$TARBALL_FILE" "$BUILD_PATH/" - cd "$BUILD_PATH" + 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 - # Ignore level 1 of tar - $TAR xvf "$TARBALL_FILE" --strip 1 + # Create and enter a second temporary build directory + builddir="$(mktemp -d)" + cd "$builddir" - "$BUILD_PATH/configure" --prefix="$PREFIX" $CONF_OPTS + # Run configure from the extracted distribution tar, + # out of the source tree + "$dist_srcdir/configure" "${CONF_OPTS[@]}" || failed_configure ;; *) echo "Standard in-tree build" - "$BUILD_PATH/configure" --prefix="$PREFIX" $CONF_OPTS + ./configure "${CONF_OPTS[@]}" || failed_configure ;; esac +# We are now inside a configured build directory + # BUILD! $MAKE -j "$($NPROC)" V=1 -$MAKE install -# Run tests +# Install in the workspace +$MAKE install DESTDIR="$WORKSPACE" + +# Run tests, don't fail now, we want to run the archiving steps +set +e $MAKE --keep-going check +ret=$? +set -e -# Cleanup +# 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 $MAKE clean # Cleanup rpath in executables and shared libraries -find "$PREFIX/lib" -name "*.so" -exec chrpath --delete {} \; +#find "$WORKSPACE/$PREFIX/bin" -type f -perm -0500 -exec chrpath --delete {} \; +find "$WORKSPACE/$PREFIX/lib" -name "*.so" -exec chrpath --delete {} \; # Remove libtool .la files -find "$PREFIX/lib" -name "*.la" -exec rm -f {} \; +find "$WORKSPACE/$PREFIX/lib" -name "*.la" -exec rm -f {} \; -# Cleanup temp directory of dist build -if [ "$build" = "dist" ]; then - cd "$SRCDIR" - rm -rf "$BUILD_PATH" -fi +# Exit with the return code of the test suite +exit $ret # EOF