summaryrefslogtreecommitdiffstats
path: root/.travis-functions.sh
diff options
context:
space:
mode:
authorRuediger Meier2014-06-02 00:58:01 +0200
committerRuediger Meier2014-06-06 16:18:44 +0200
commitdd68764c592dfc9992e1be333b2ce4bbd00eecb5 (patch)
tree6ee8789fb39ce1960f90dd94458885142dd84a0e /.travis-functions.sh
parentlibsmartcols: add debug messages (diff)
downloadkernel-qcow2-util-linux-dd68764c592dfc9992e1be333b2ce4bbd00eecb5.tar.gz
kernel-qcow2-util-linux-dd68764c592dfc9992e1be333b2ce4bbd00eecb5.tar.xz
kernel-qcow2-util-linux-dd68764c592dfc9992e1be333b2ce4bbd00eecb5.zip
travis-ci: refactor and add .travis-functions.sh
Travis yaml syntax, where we can only use shell one-liners, is awful and ugly. We add a real shell script and source it from .travis.yml. This commit squashes a lot changes because we don't want to pollute history with this meta CI stuff. Highlights of this commit: - enable make distcheck - cleanup configure options (enable all progs, with python and docs) - shorter config.log dump - out-of-tree build supported - workaround broken libtool on travis host - now it's easy to add temporary debugging stuff - testing locally is possible now What are we testing now: - gcc and clang compiler - configure mostly with --enable-all-programs, --with-python and --enable-gtk-doc - make check with and without root permissions - make distcheck - make install (with and without --prefix as well as DESTDIR=...) - usually we always build in-tree but distcheck does out-of-tree What do we want/expect at all: - This travis setup is intended to always work without fixing or updating this build script all the time. Thats why we only use a few configure flags. - We want to avoid predictable failures on travis host to not make developers tired of this machinery. Any tested feature which is known to be (sometimes) broken should be fixed or skipped as soon as possible. - If this works like wanted then in future almost any point in master commit history should at least survive the build and common tests on this reference host/arch. Moreover we will have a comparable, deterministic build log history. This could make bisecting real bugs easier. - It's not our goal to test any kind of config flags, host setup and arch combination. This would be done better by external build scripts which do not live within the project itself. - Of course this machinery can be also used to reproduce bugs with more exotic config and host setup by pushing a debug branch with modified travis script to github. Signed-off-by: Ruediger Meier <ruediger.meier@ga-group.nl>
Diffstat (limited to '.travis-functions.sh')
-rwxr-xr-x.travis-functions.sh128
1 files changed, 128 insertions, 0 deletions
diff --git a/.travis-functions.sh b/.travis-functions.sh
new file mode 100755
index 000000000..ed491f417
--- /dev/null
+++ b/.travis-functions.sh
@@ -0,0 +1,128 @@
+#!/bin/bash
+
+#
+# .travis-functions.sh:
+# - helper functions to be sourced from .travis.yml
+# - designed to respect travis' environment but testing locally is possible
+#
+
+if [ ! -f "configure.ac" ]; then
+ echo ".travis-functions.sh must be sourced from source dir" >&2
+ return 1 || exit 1
+fi
+
+# some config settings
+MAKE="make -j4"
+DUMP_CONFIG_LOG="short"
+
+# We could test (exotic) out-of-tree build dirs using relative or abs paths.
+# After sourcing this script we are living in build dir. Tasks for source dir
+# have to use $SOURCE_DIR.
+SOURCE_DIR="."
+BUILD_DIR="."
+CONFIGURE="$SOURCE_DIR/configure"
+
+mkdir -p "$BUILD_DIR"
+cd "$BUILD_DIR" || return 1 || exit 1
+
+function configure_travis
+{
+ "$CONFIGURE" "$@"
+ err=$?
+ if [ "$DUMP_CONFIG_LOG" = "short" ]; then
+ grep -B1 -A10000 "^## Output variables" config.log | grep -v "_FALSE="
+ elif [ "$DUMP_CONFIG_LOG" = "full" ]; then
+ cat config.log
+ fi
+ return $err
+}
+
+function check_nonroot
+{
+ configure_travis \
+ --disable-use-tty-group \
+ --with-python \
+ --enable-all-programs \
+ --enable-gtk-doc \
+ || return
+ $MAKE || return
+ $MAKE check || return
+ $MAKE install DESTDIR=/tmp/dest || return
+}
+
+function check_root
+{
+ configure_travis \
+ --with-python \
+ --enable-all-programs \
+ || return
+ $MAKE || return
+ $MAKE check TS_COMMAND="true" || return
+ sudo -E $MAKE check TS_OPTS='--parallel=1' || return
+ sudo $MAKE install || return
+}
+
+function check_dist
+{
+ configure_travis \
+ || return
+ $MAKE distcheck || return
+}
+
+function travis_before_script
+{
+ pushd "$SOURCE_DIR" || return
+ set -o xtrace
+
+ ./autogen.sh
+ ret=$?
+
+ # workaround for broken pylibmount install relink
+ [ $ret -eq 0 ] && \
+ sed -i 's/\(link_all_deplibs\)=no/\1=unknown/' ./configure
+
+ set +o xtrace
+ popd
+ return $ret
+}
+
+function travis_script
+{
+ local ret
+ set -o xtrace
+
+ case "$MAKE_CHECK" in
+ nonroot)
+ check_nonroot
+ ;;
+ root)
+ check_root
+ ;;
+ dist)
+ check_dist
+ ;;
+ *)
+ echo "error, check environment (travis.yml)" >&2
+ false
+ ;;
+ esac
+
+ # We exit here with case-switch return value!
+ ret=$?
+ set +o xtrace
+ return $ret
+}
+
+function travis_after_script
+{
+ local diff_dir
+ local tmp
+
+ # find diff dir from check as well as from distcheck
+ diff_dir=$(find -type d -a -name "diff" | grep "tests/diff" | head -n 1)
+ if [ -d "$diff_dir" ]; then
+ tmp=$(find "$diff_dir" -type f | sort)
+ echo -en "dump test diffs:\n${tmp}\n"
+ echo "$tmp" | xargs -r cat
+ fi
+}