diff options
author | Ruediger Meier | 2014-06-02 00:58:01 +0200 |
---|---|---|
committer | Ruediger Meier | 2014-06-06 16:18:44 +0200 |
commit | dd68764c592dfc9992e1be333b2ce4bbd00eecb5 (patch) | |
tree | 6ee8789fb39ce1960f90dd94458885142dd84a0e /.travis-functions.sh | |
parent | libsmartcols: add debug messages (diff) | |
download | kernel-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.sh | 128 |
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 +} |