X-Git-Url: http://git.lttng.org./?a=blobdiff_plain;f=scripts%2Flttng-ust%2Fbuild.sh;h=8c6e47c9a6012c6bd135079a85a7a414576e8562;hb=88b3026879d7a56fbb2c892b8a1c9bca0fecc3b4;hp=3d52a4965c1e03e4ab9a451204d5d2c9bad6dddf;hpb=8a67d4900aa6758edac048c9b4681614ea76133e;p=lttng-ci.git diff --git a/scripts/lttng-ust/build.sh b/scripts/lttng-ust/build.sh index 3d52a49..8c6e47c 100755 --- a/scripts/lttng-ust/build.sh +++ b/scripts/lttng-ust/build.sh @@ -1,59 +1,188 @@ -# Create build directory -rm -rf $WORKSPACE/build -mkdir -p $WORKSPACE/build +#!/bin/bash -exu +# +# Copyright (C) 2015, Jonathan Rajotte-Julien +# 2016, 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 +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . + +# Required parameters +arch=${arch:-} +conf=${conf:-} +build=${build:-} -# liburcu -URCU_INCS="$WORKSPACE/dependencies/liburcu/build/include/" -URCU_LIBS="$WORKSPACE/dependencies/liburcu/build/lib/" -export CPPFLAGS="-I$URCU_INCS" -export LDFLAGS="-L$URCU_LIBS" -export LD_LIBRARY_PATH="$URCU_LIBS:$LD_LIBRARY_PATH" +# liburcu +URCU_INCS="$WORKSPACE/deps/liburcu/build/include/" +URCU_LIBS="$WORKSPACE/deps/liburcu/build/lib/" +SRCDIR="$WORKSPACE/src/lttng-ust" +TMPDIR="$WORKSPACE/tmp" PREFIX="$WORKSPACE/build" -./bootstrap +# Create build and tmp directories +rm -rf "$PREFIX" "$TMPDIR" +mkdir -p "$PREFIX" "$TMPDIR" + +export TMPDIR +export CFLAGS="-g -O2" + +# Set platform variables +case "$arch" in +*) + MAKE=make + TAR=tar + NPROC=nproc + #BISON="bison" + #YACC="$BISON -y" + #CFLAGS="" + ;; +esac + +# Export time env. variables flags +export LD_LIBRARY_PATH="$URCU_LIBS:${LD_LIBRARY_PATH:-}" + +# Define flags +CPPFLAGS="-I$URCU_INCS" +LDFLAGS="-L$URCU_LIBS" -CONF_OPTS="" +# Set configure options for each build configuration +CONF_OPTS="" case "$conf" in -# Unsupported! liblttng-ust can't pull in it's static (.a) dependencies. -#static) -# echo "Static build" -# CONF_OPTS="--enable-static --disable-shared" -# ;; -java-agent) - echo "Java agent build" +static) + # Unsupported! liblttng-ust can't pull in it's static (.a) dependencies. + echo "Static build" + CONF_OPTS="--enable-static --disable-shared" + ;; + +agents) + echo "Enable Java agent build" export CLASSPATH="/usr/share/java/log4j-1.2.jar" - CONF_OPTS="--enable-java-agent-all" + CONF_OPTS+=" --enable-java-agent-all --enable-jni-interface" + + echo "Enable Python agent build" + CONF_OPTS+=" --enable-python-agent" + ;; + +debug-rcu) + echo "Enable RCU sanity checks for debugging" + CPPFLAGS="${CPPFLAGS:-} -DDEBUG_RCU" ;; + *) echo "Standard build" CONF_OPTS="" ;; esac -./configure --prefix=$PREFIX $CONF_OPTS -make V=1 -make install +# Enter the source directory +cd "$SRCDIR" + +# Run bootstrap in the source directory prior to configure +./bootstrap + + +# Build type +# 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 +case "$build" in +oot) + echo "Out of tree build" + BUILD_PATH=$WORKSPACE/oot + + mkdir -p "$BUILD_PATH" + cd "$BUILD_PATH" + + CPPFLAGS="$CPPFLAGS" LDFLAGS="$LDFLAGS" "$SRCDIR/configure" --prefix="$PREFIX" $CONF_OPTS + ;; + +dist) + echo "Distribution tarball in-tree build" + + # Initial configure and generate tarball + CPPFLAGS="$CPPFLAGS" LDFLAGS="$LDFLAGS" "$SRCDIR/configure" + $MAKE dist + + BUILD_PATH="$(mktemp -d)" + cp ./*.tar.* "$BUILD_PATH/" + cd "$BUILD_PATH" + + # Ignore level 1 of tar + $TAR xvf ./*.tar.* --strip 1 + + # Build in extracted source tree + CPPFLAGS="$CPPFLAGS" LDFLAGS="$LDFLAGS" "$BUILD_PATH/configure" --prefix="$PREFIX" $CONF_OPTS + ;; + +oot-dist) + echo "Distribution tarball out of tree build" + BUILD_PATH="$(mktemp -d)" + cd "$BUILD_PATH" + + # Initial configure and generate tarball + CPPFLAGS="$CPPFLAGS" LDFLAGS="$LDFLAGS" "$SRCDIR/configure" + $MAKE dist + + NEWSRC_PATH="$(mktemp -d)" + cp ./*.tar.* "$NEWSRC_PATH/" + cd "$NEWSRC_PATH" + + # Ignore level 1 of tar + $TAR xvf ./*.tar.* --strip 1 + + BUILD_PATH="$(mktemp -d)" + cd "$BUILD_PATH" + + # Build oot from extracted sources + CPPFLAGS="$CPPFLAGS" LDFLAGS="$LDFLAGS" "$NEWSRC_PATH/configure" --prefix="$PREFIX" $CONF_OPTS + ;; + +*) + echo "Standard in-tree build" + CPPFLAGS="$CPPFLAGS" LDFLAGS="$LDFLAGS" "$BUILD_PATH/configure" --prefix="$PREFIX" $CONF_OPTS + ;; +esac + +# BUILD! +$MAKE -j "$($NPROC)" V=1 +$MAKE install # Run tests -rm -rf $WORKSPACE/tap -mkdir -p $WORKSPACE/tap/unit +$MAKE --keep-going check -cd $WORKSPACE/tests +# Copy tap logs for the jenkins tap parser +rsync -a --exclude 'test-suite.log' --include '*/' --include '*.log' --exclude='*' tests/ "$WORKSPACE/tap" -prove --merge --exec '' - < $WORKSPACE/tests/unit_tests --archive $WORKSPACE/tap/unit/ || true +# Clean the build directory +$MAKE clean -# TAP plugin is having a hard time with .yml files. -rm -f $WORKSPACE/tap/unit/meta.yml +# Cleanup rpath in executables and shared libraries +find "$PREFIX/lib" -name "*.so" -exec chrpath --delete {} \; -# And also with files without extension, so rename all result to *.tap -find $WORKSPACE/tap/unit/ -type f -exec mv {} {}.tap \; +# Remove libtool .la files +find "$PREFIX/lib" -name "*.la" -exec rm -f {} \; -# Cleanup -make clean +# Clean temp dir for dist build +if [ "$build" = "dist" ]; then + cd "$SRCDIR" + rm -rf "$BUILD_PATH" +fi -# Cleanup rpath and libtool .la files -find $WORKSPACE/build/lib -name "*.so" -exec chrpath --delete {} \; -find $WORKSPACE/build/lib -name "*.la" -exec rm -f {} \; +# EOF