summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2018-01-19 10:18:55 -0500
committerNick Mathewson <nickm@torproject.org>2018-01-19 10:18:55 -0500
commit63e549a6b4b57b2d70b83d14418bcad1f86136ce (patch)
tree7aeba3b3e1b5769f7630c0eef92293ef44ca6deb
parent9652c65fa3b9b3346d346daea05c8b3c22b3e125 (diff)
parent3bf9174fa37ed09b796dd34c0c2918dae7d4de0d (diff)
downloadtor-63e549a6b4b57b2d70b83d14418bcad1f86136ce.tar.gz
tor-63e549a6b4b57b2d70b83d14418bcad1f86136ce.zip
Merge remote-tracking branch 'tlyu-github/travis-workaround-master'
-rw-r--r--.travis.yml42
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