diff options
author | Nick Mathewson <nickm@torproject.org> | 2018-01-19 10:18:55 -0500 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2018-01-19 10:18:55 -0500 |
commit | 63e549a6b4b57b2d70b83d14418bcad1f86136ce (patch) | |
tree | 7aeba3b3e1b5769f7630c0eef92293ef44ca6deb | |
parent | 9652c65fa3b9b3346d346daea05c8b3c22b3e125 (diff) | |
parent | 3bf9174fa37ed09b796dd34c0c2918dae7d4de0d (diff) | |
download | tor-63e549a6b4b57b2d70b83d14418bcad1f86136ce.tar.gz tor-63e549a6b4b57b2d70b83d14418bcad1f86136ce.zip |
Merge remote-tracking branch 'tlyu-github/travis-workaround-master'
-rw-r--r-- | .travis.yml | 42 |
1 files changed, 37 insertions, 5 deletions
diff --git a/.travis.yml b/.travis.yml index d3918875dd..6c6e1ace2b 100644 --- a/.travis.yml +++ b/.travis.yml @@ -1,8 +1,10 @@ language: c -compiler: - - gcc - - clang +## Comment out the compiler list for now to allow an explicit build +## matrix. +# compiler: +# - gcc +# - clang notifications: irc: @@ -28,6 +30,10 @@ dist: trusty ## We don't need sudo. (The "apt:" stanza after this allows us to not need sudo; ## otherwise, we would need it for getting dependencies.) +## +## We override this in the explicit build matrix to work around a +## Travis CI environment regression +## https://github.com/travis-ci/travis-ci/issues/9033 sudo: false ## (Linux only) Download our dependencies @@ -55,9 +61,13 @@ env: ## The Travis CI environment allows us two cores, so let's use both. - MAKEFLAGS="-j 2" matrix: + ## Leave at least one entry here or Travis seems to generate a + ## matrix entry with empty matrix environment variables. Leaving + ## more than one entry causes unwanted matrix entries with + ## unspecified compilers. - RUST_OPTIONS="--enable-rust --enable-cargo-online-mode" - - RUST_OPTIONS="--enable-rust" TOR_RUST_DEPENDENCIES=true - - RUST_OPTIONS="" + # - RUST_OPTIONS="--enable-rust" TOR_RUST_DEPENDENCIES=true + # - RUST_OPTIONS="" matrix: ## If one build in the matrix fails (e.g. if building withour Rust and Clang @@ -65,6 +75,28 @@ matrix: ## entire job early and call the whole thing a failure. fast_finish: true + ## Create explicit matrix entries to work around a Travis CI + ## environment issue. Missing keys inherit from the first list + ## entry under that key outside the "include" clause. + include: + - compiler: gcc + - compiler: gcc + env: RUST_OPTIONS="--enable-rust" TOR_RUST_DEPENDENCIES=true + - compiler: gcc + env: RUST_OPTIONS="" + ## The "sudo: required" forces non-containerized builds, working + ## around a Travis CI environment issue: clang LeakAnalyzer fails + ## because it requires ptrace and the containerized environment no + ## longer allows ptrace. + - compiler: clang + sudo: required + - compiler: clang + sudo: required + env: RUST_OPTIONS="--enable-rust" TOR_RUST_DEPENDENCIES=true + - compiler: clang + sudo: required + env: RUST_OPTIONS="" + before_install: ## If we're on OSX, homebrew usually needs to updated first - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then brew update ; fi |