2019-03-28 19:12:50 -04:00
# The test build matrix (stage: test) is constructed to test a wide range of
# configurations, rather than a single pass/fail. This helps to catch build
# failures and logic errors that present on platforms other than the ones the
# author has tested.
#
# Some builders use the dependency-generator in `./depends`, rather than using
# apt-get to install build dependencies. This guarantees that the tester is
# using the same versions as Gitian, so the build results are nearly identical
# to what would be found in a final release.
#
# In order to avoid rebuilding all dependencies for each build, the binaries
# are cached and re-used when possible. Changes in the dependency-generator
# will trigger cache-invalidation and rebuilds as necessary.
#
# These caches can be manually removed if necessary. This is one of the very
# few manual operations that is possible with Travis, and it can be done by a
# Bitcoin Core GitHub member via the Travis web interface [0].
#
# Travis CI uploads the cache after the script phase of the build [1].
# However, the build is terminated without saving the chache if it takes over
# 50 minutes [2]. Thus, if we spent too much time in early build stages, fail
# with an error and save the cache.
#
# [0] https://travis-ci.org/bitcoin/bitcoin/caches
# [1] https://docs.travis-ci.com/user/caching/#build-phases
# [2] https://docs.travis-ci.com/user/customizing-the-build#build-timeouts
2018-12-28 08:26:14 -06:00
dist : xenial
2014-08-20 13:00:00 -04:00
os : linux
2017-10-18 14:24:21 -04:00
language : minimal
2016-05-17 17:54:41 -04:00
cache :
2018-03-05 17:23:35 -05:00
ccache : true
2016-05-17 17:54:41 -04:00
directories :
2019-06-14 10:49:00 -04:00
- $TRAVIS_BUILD_DIR/depends/built
- $TRAVIS_BUILD_DIR/depends/sdk-sources
2018-08-03 15:39:05 +02:00
- $HOME/.ccache
2018-05-07 17:24:19 +07:00
stages :
2018-05-12 21:43:30 +02:00
- lint
2018-05-07 17:24:19 +07:00
- test
2018-12-14 14:50:21 +01:00
- extended-lint
2014-08-20 13:00:00 -04:00
env :
global :
- MAKEJOBS=-j3
2018-08-24 19:20:25 -04:00
- RUN_UNIT_TESTS=true
- RUN_FUNCTIONAL_TESTS=true
2019-01-16 11:49:01 -05:00
- RUN_FUZZ_TESTS=false
2018-07-26 14:07:09 -04:00
- DOCKER_NAME_TAG=ubuntu:18.04
2015-03-05 11:49:06 -05:00
- BOOST_TEST_RANDOM=1$TRAVIS_BUILD_ID
2014-08-20 13:00:00 -04:00
- CCACHE_SIZE=100M
- CCACHE_TEMPDIR=/tmp/.ccache-temp
- CCACHE_COMPRESS=1
2018-05-11 18:16:42 +08:00
- CCACHE_DIR=$HOME/.ccache
2014-08-20 13:00:00 -04:00
- BASE_OUTDIR=$TRAVIS_BUILD_DIR/out
2016-06-20 14:57:39 +02:00
- SDK_URL=https://bitcoincore.org/depends-sources/sdks
2015-05-04 11:05:25 -04:00
- WINEDEBUG=fixme-all
2018-05-11 18:16:42 +08:00
- DOCKER_PACKAGES="build-essential libtool autotools-dev automake pkg-config bsdmainutils curl git ca-certificates ccache"
2019-03-28 19:12:50 -04:00
- CACHE_ERR_MSG="Error! Initial build successful, but not enough time remains to run later build stages and tests. Please manually re-run this job by using the travis restart button or asking a bitcoin maintainer to restart. The next run should not time out because the build cache has been saved."
2018-08-02 12:22:55 +02:00
before_install :
2018-12-13 21:18:14 +08:00
- set -o errexit; source .travis/test_03_before_install.sh
2018-08-02 12:22:55 +02:00
install :
2018-12-13 21:18:14 +08:00
- set -o errexit; source .travis/test_04_install.sh
2018-08-02 12:22:55 +02:00
before_script :
2018-12-13 21:18:14 +08:00
- set -o errexit; source .travis/test_05_before_script.sh
2018-08-02 12:22:55 +02:00
script :
2019-03-28 19:12:50 -04:00
- export CONTINUE=1
- if [ $SECONDS -gt 1200 ]; then export CONTINUE=0; fi # Likely the depends build took very long
- if [ $CONTINUE = "1" ]; then set -o errexit; source .travis/test_06_script_a.sh; else set +o errexit; echo "$CACHE_ERR_MSG"; false; fi
2019-04-11 13:52:02 -04:00
- if [ $SECONDS -gt 2000 ]; then export CONTINUE=0; fi # Likely the build took very long; The tests take about 1000s, so we should abort if we have less than 50*60-1000=2000s left
2019-03-28 19:12:50 -04:00
- if [ $CONTINUE = "1" ]; then set -o errexit; source .travis/test_06_script_b.sh; else set +o errexit; echo "$CACHE_ERR_MSG"; false; fi
2018-08-02 12:22:55 +02:00
after_script :
2018-08-03 15:39:05 +02:00
- echo $TRAVIS_COMMIT_RANGE
- echo $TRAVIS_COMMIT_LOG
2018-08-02 12:22:55 +02:00
jobs :
include :
2018-12-21 12:37:46 -06:00
2018-08-03 15:39:05 +02:00
- stage : lint
2018-12-21 12:37:46 -06:00
name : 'lint'
2018-08-03 15:39:05 +02:00
env :
cache : false
language : python
2019-02-20 18:13:43 -05:00
python : '3.5' # Oldest supported version according to doc/dependencies.md
2018-08-03 15:39:05 +02:00
install :
2018-08-03 18:05:22 +02:00
- set -o errexit; source .travis/lint_04_install.sh
2018-08-03 15:39:05 +02:00
before_script :
2018-08-03 18:05:22 +02:00
- set -o errexit; source .travis/lint_05_before_script.sh
2018-08-03 15:39:05 +02:00
script :
2018-08-03 18:05:22 +02:00
- set -o errexit; source .travis/lint_06_script.sh
2018-12-21 12:37:46 -06:00
2018-12-14 14:50:21 +01:00
- stage : extended-lint
name : 'extended lint [runtime >= 60 seconds]'
env :
cache : false
language : python
python : '3.5'
install :
- set -o errexit; source .travis/extended_lint_04_install.sh
before_script :
- set -o errexit; source .travis/lint_05_before_script.sh
script :
- set -o errexit; source .travis/extended_lint_06_script.sh
2018-08-02 12:22:55 +02:00
- stage : test
2018-12-21 12:37:46 -06:00
name: 'ARM [GOAL : install] [no unit or functional tests]'
2018-08-02 12:22:55 +02:00
env : >-
2018-07-27 11:53:40 +02:00
HOST=arm-linux-gnueabihf
2018-08-30 01:44:21 +08:00
PACKAGES="python3 g++-arm-linux-gnueabihf"
2018-08-24 19:20:25 -04:00
RUN_UNIT_TESTS=false
RUN_FUNCTIONAL_TESTS=false
2018-07-27 11:53:40 +02:00
GOAL="install"
2018-08-05 01:20:22 +08:00
# -Wno-psabi is to disable ABI warnings: "note: parameter passing for argument of type ... changed in GCC 7.1"
# This could be removed once the ABI change warning does not show up by default
BITCOIN_CONFIG="--enable-glibc-back-compat --enable-reduce-exports CXXFLAGS=-Wno-psabi"
2018-12-21 12:37:46 -06:00
2018-08-02 12:22:55 +02:00
- stage : test
2019-02-07 19:18:02 -05:00
name: 'Win64 [GOAL : deploy] [no gui or functional tests]'
2018-08-02 12:22:55 +02:00
env : >-
2018-07-27 11:53:40 +02:00
HOST=x86_64-w64-mingw32
PACKAGES="python3 nsis g++-mingw-w64-x86-64 wine-binfmt wine64"
2019-02-07 19:18:02 -05:00
RUN_FUNCTIONAL_TESTS=false
2018-08-30 01:44:21 +08:00
GOAL="deploy"
BITCOIN_CONFIG="--enable-reduce-exports --disable-gui-tests"
2018-12-21 12:37:46 -06:00
2018-08-02 12:22:55 +02:00
- stage : test
2019-02-14 14:59:18 -05:00
name: '32-bit + dash [GOAL: install] [GUI : no BIP70]'
2018-08-02 12:22:55 +02:00
env : >-
2018-07-27 11:53:40 +02:00
HOST=i686-pc-linux-gnu
PACKAGES="g++-multilib python3-zmq"
GOAL="install"
2019-02-14 14:59:18 -05:00
BITCOIN_CONFIG="--enable-zmq --with-gui=qt5 --disable-bip70 --enable-glibc-back-compat --enable-reduce-exports LDFLAGS=-static-libstdc++"
2018-07-27 11:53:40 +02:00
CONFIG_SHELL="/bin/dash"
2018-12-21 12:37:46 -06:00
2018-08-02 12:22:55 +02:00
- stage : test
2018-12-21 12:37:46 -06:00
name: 'x86_64 Linux [GOAL : install] [bionic] [uses qt5 dev package instead of depends Qt to speed up build and avoid timeout]'
2018-08-02 12:22:55 +02:00
env : >-
2018-07-27 11:53:40 +02:00
HOST=x86_64-unknown-linux-gnu
PACKAGES="python3-zmq qtbase5-dev qttools5-dev-tools protobuf-compiler libdbus-1-dev libharfbuzz-dev libprotobuf-dev"
DEP_OPTS="NO_QT=1 NO_UPNP=1 DEBUG=1 ALLOW_HOST_PACKAGES=1"
2019-05-02 16:48:05 -04:00
TEST_RUNNER_EXTRA="--coverage --extended --exclude feature_dbcrash" # Run extended tests so that coverage does not fail, but exclude the very slow dbcrash
2018-07-27 11:53:40 +02:00
GOAL="install"
2019-01-16 11:49:01 -05:00
BITCOIN_CONFIG="--enable-zmq --with-gui=qt5 --enable-glibc-back-compat --enable-reduce-exports --enable-debug CXXFLAGS=\"-g0 -O2\""
2018-12-21 12:37:46 -06:00
2019-01-28 11:42:59 -05:00
- stage : test
2019-01-31 22:13:45 -08:00
name: 'x86_64 Linux [GOAL : install] [trusty] [no functional tests, no depends, only system libs]'
2019-01-28 11:42:59 -05:00
env : >-
HOST=x86_64-unknown-linux-gnu
DOCKER_NAME_TAG=ubuntu:14.04
PACKAGES="python3-zmq qtbase5-dev qttools5-dev-tools libicu-dev libpng-dev libssl-dev libevent-dev bsdmainutils libboost-system-dev libboost-filesystem-dev libboost-chrono-dev libboost-test-dev libboost-thread-dev libdb5.1++-dev libminiupnpc-dev libzmq3-dev libprotobuf-dev protobuf-compiler libqrencode-dev"
2019-01-30 15:18:30 -08:00
NO_DEPENDS=1
2019-01-28 11:42:59 -05:00
RUN_FUNCTIONAL_TESTS=false
GOAL="install"
BITCOIN_CONFIG="--enable-zmq --with-incompatible-bdb --with-gui=no"
2018-10-20 07:31:56 -03:00
- stage : test
2018-12-21 12:37:46 -06:00
name: 'x86_64 Linux [GOAL: install] [xenial] [no depends, only system libs, sanitizers : thread (TSan), no wallet]'
2018-10-20 07:31:56 -03:00
env : >-
HOST=x86_64-unknown-linux-gnu
DOCKER_NAME_TAG=ubuntu:16.04
2018-11-19 09:11:18 -05:00
PACKAGES="clang llvm python3-zmq qtbase5-dev qttools5-dev-tools libssl-dev libevent-dev bsdmainutils libboost-system-dev libboost-filesystem-dev libboost-chrono-dev libboost-test-dev libboost-thread-dev libdb5.3++-dev libminiupnpc-dev libzmq3-dev libprotobuf-dev protobuf-compiler libqrencode-dev"
2018-10-20 07:31:56 -03:00
NO_DEPENDS=1
GOAL="install"
2018-11-27 10:21:29 +01:00
BITCOIN_CONFIG="--enable-zmq --disable-wallet --with-gui=qt5 CPPFLAGS=-DDEBUG_LOCKORDER --with-sanitizers=thread --disable-hardening --disable-asm CC=clang CXX=clang++"
2018-12-21 12:37:46 -06:00
2018-08-24 19:20:25 -04:00
- stage : test
2018-12-21 12:37:46 -06:00
name: 'x86_64 Linux [GOAL: install] [bionic] [no depends, only system libs, sanitizers : address/leak (ASan + LSan) + undefined (UBSan) + integer]'
2018-08-24 19:20:25 -04:00
env : >-
HOST=x86_64-unknown-linux-gnu
2018-11-06 16:17:23 +01:00
PACKAGES="clang llvm python3-zmq qtbase5-dev qttools5-dev-tools libssl1.0-dev libevent-dev bsdmainutils libboost-system-dev libboost-filesystem-dev libboost-chrono-dev libboost-test-dev libboost-thread-dev libdb5.3++-dev libminiupnpc-dev libzmq3-dev libprotobuf-dev protobuf-compiler libqrencode-dev"
2018-08-24 19:20:25 -04:00
NO_DEPENDS=1
GOAL="install"
2018-11-15 15:08:28 +01:00
BITCOIN_CONFIG="--enable-zmq --with-incompatible-bdb --with-gui=qt5 CPPFLAGS=-DDEBUG_LOCKORDER --with-sanitizers=address,integer,undefined CC=clang CXX=clang++"
2018-12-21 12:37:46 -06:00
2019-01-16 11:49:01 -05:00
- stage : test
name: 'x86_64 Linux [GOAL: install] [bionic] [no depends, only system libs, sanitizers : fuzzer,address]'
env : >-
HOST=x86_64-unknown-linux-gnu
PACKAGES="clang llvm python3 libssl1.0-dev libevent-dev bsdmainutils libboost-system-dev libboost-filesystem-dev libboost-chrono-dev libboost-test-dev libboost-thread-dev"
NO_DEPENDS=1
RUN_UNIT_TESTS=false
RUN_FUNCTIONAL_TESTS=false
RUN_FUZZ_TESTS=true
GOAL="install"
2019-07-08 20:28:58 -04:00
BITCOIN_CONFIG="--enable-fuzz --with-sanitizers=fuzzer,address CC=clang CXX=clang++"
2019-01-16 11:49:01 -05:00
2018-08-02 12:22:55 +02:00
- stage : test
2018-12-21 12:37:46 -06:00
name: 'x86_64 Linux [GOAL : install] [bionic] [no wallet]'
2018-08-02 12:22:55 +02:00
env : >-
2018-07-27 11:53:40 +02:00
HOST=x86_64-unknown-linux-gnu
2018-09-23 11:34:51 -04:00
PACKAGES="python3-zmq"
2018-07-27 11:53:40 +02:00
DEP_OPTS="NO_WALLET=1"
GOAL="install"
BITCOIN_CONFIG="--enable-glibc-back-compat --enable-reduce-exports"
2018-12-21 12:37:46 -06:00
2018-08-02 12:22:55 +02:00
- stage : test
2019-01-31 22:13:45 -08:00
name: 'macOS 10.10 [GOAL : deploy] [no functional tests]'
2018-08-02 12:22:55 +02:00
env : >-
2018-07-27 11:53:40 +02:00
HOST=x86_64-apple-darwin14
2019-03-14 15:08:54 -04:00
PACKAGES="cmake imagemagick libcap-dev librsvg2-bin libz-dev libbz2-dev libtiff-tools python3-dev python3-setuptools"
2018-07-27 11:53:40 +02:00
OSX_SDK=10.11
2018-08-24 19:20:25 -04:00
RUN_UNIT_TESTS=false
RUN_FUNCTIONAL_TESTS=false
2018-08-30 01:44:21 +08:00
GOAL="deploy"
2018-08-02 12:22:55 +02:00
BITCOIN_CONFIG="--enable-gui --enable-reduce-exports --enable-werror"