Merge branch 'maint-0.3.1' into maint-0.3.2
[tor.git] / .travis.yml
blob8dcbf1fe9d8ed0c7e0f6e9fd433e274485bd54e0
1 language: c
3 ## Comment out the compiler list for now to allow an explicit build
4 ## matrix.
5 # compiler:
6 #   - gcc
7 #   - clang
9 notifications:
10   irc:
11     channels:
12       - "irc.oftc.net#tor-ci"
13     template:
14       - "%{repository} %{branch} %{commit} - %{author}: %{commit_subject}"
15       - "Build #%{build_number} %{result}. Details: %{build_url}"
16     on_success: change
17     on_failure: change
18   email:
19     on_success: never
20     on_failure: change
22 os:
23   - linux
24   ## Uncomment the following line to also run the entire build matrix on OSX.
25   ## This will make your CI builds take roughly ten times longer to finish.
26   # - osx
28 ## Use the Ubuntu Trusty images.
29 dist: trusty
31 ## We don't need sudo. (The "apt:" stanza after this allows us to not need sudo;
32 ## otherwise, we would need it for getting dependencies.)
34 ## We override this in the explicit build matrix to work around a
35 ## Travis CI environment regression
36 ## https://github.com/travis-ci/travis-ci/issues/9033
37 sudo: false
39 ## (Linux only) Download our dependencies
40 addons:
41   apt:
42     packages:
43       ## Required dependencies
44       - libevent-dev
45       - libseccomp2
46       - zlib1g-dev
47       ## Optional dependencies
48       - liblzma-dev
49       - libscrypt-dev
50       ## zstd doesn't exist in Ubuntu Trusty
51       #- libzstd
53 ## The build matrix in the following two stanzas expands into four builds (per OS):
55 ##  * with GCC, with Rust
56 ##  * with GCC, without Rust
57 ##  * with Clang, with Rust
58 ##  * with Clang, without Rust
59 env:
60   global:
61     ## The Travis CI environment allows us two cores, so let's use both.
62     - MAKEFLAGS="-j 2"
63   matrix:
64     ## Leave at least one entry here or Travis seems to generate a
65     ## matrix entry with empty matrix environment variables.  Leaving
66     ## more than one entry causes unwanted matrix entries with
67     ## unspecified compilers.
68     - RUST_OPTIONS="--enable-rust --enable-cargo-online-mode"
69     # - RUST_OPTIONS=""
71 matrix:
72   ## Uncomment to allow the build to report success (with non-required
73   ## sub-builds continuing to run) if all required sub-builds have
74   ## succeeded.  This is somewhat buggy currently: it can cause
75   ## duplicate notifications and prematurely report success if a
76   ## single sub-build has succeeded.  See
77   ## https://github.com/travis-ci/travis-ci/issues/1696
78   # fast_finish: true
80   ## Uncomment the appropriate lines below to allow the build to
81   ## report success even if some less-critical sub-builds fail and it
82   ## seems likely to take a while for someone to fix it.  Currently
83   ## Travis CI doesn't distinguish "all builds succeeded" from "some
84   ## non-required sub-builds failed" except on the individual build's
85   ## page, which makes it somewhat annoying to detect from the
86   ## branches and build history pages.  See
87   ## https://github.com/travis-ci/travis-ci/issues/8716
88   allow_failures:
89     # - env: RUST_OPTIONS="--enable-rust" TOR_RUST_DEPENDENCIES=true
90     # - env: RUST_OPTIONS="--enable-rust --enable-cargo-online-mode
91     # - compiler: clang
93   ## Create explicit matrix entries to work around a Travis CI
94   ## environment issue.  Missing keys inherit from the first list
95   ## entry under that key outside the "include" clause.
96   include:
97     - compiler: gcc
98     - compiler: gcc
99       env: RUST_OPTIONS=""
100     - compiler: gcc
101       env: COVERAGE_OPTIONS="--enable-coverage"
102     - compiler: gcc
103       env: DISTCHECK="yes"
104     ## The "sudo: required" forces non-containerized builds, working
105     ## around a Travis CI environment issue: clang LeakAnalyzer fails
106     ## because it requires ptrace and the containerized environment no
107     ## longer allows ptrace.
108     - compiler: clang
109       sudo: required
110     - compiler: clang
111       sudo: required
112       env: RUST_OPTIONS=""
114 before_install:
115   ## If we're on OSX, homebrew usually needs to updated first
116   - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then brew update ; fi
117   ## Download rustup
118   - if [[ "$RUST_OPTIONS" != "" ]]; then curl -Ssf -o rustup.sh https://sh.rustup.rs; fi
119   - if [[ "$COVERAGE_OPTIONS" != "" ]]; then pip install --user cpp-coveralls; fi
121 install:
122   ## If we're on OSX use brew to install required dependencies (for Linux, see the "apt:" section above)
123   - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then { brew outdated openssl    || brew upgrade openssl;    }; fi
124   - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then { brew outdated libevent   || brew upgrade libevent;   }; fi
125   - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then { brew outdated pkg-config || brew upgrade pkg-config; }; fi
126   ## If we're on OSX also install the optional dependencies
127   - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then { brew outdated xz         || brew upgrade xz;         }; fi
128   - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then { brew outdated libscrypt  || brew upgrade libscrypt;  }; fi
129   - if [[ "$TRAVIS_OS_NAME" == "osx" ]]; then { brew outdated zstd       || brew upgrade zstd;       }; fi
130   ## Install the stable channels of rustc and cargo and setup our toolchain environment
131   - if [[ "$RUST_OPTIONS" != "" ]]; then sh rustup.sh -y --default-toolchain stable; fi
132   - if [[ "$RUST_OPTIONS" != "" ]]; then source $HOME/.cargo/env; fi
133   ## Get some info about rustc and cargo
134   - if [[ "$RUST_OPTIONS" != "" ]]; then which rustc; fi
135   - if [[ "$RUST_OPTIONS" != "" ]]; then which cargo; fi
136   - if [[ "$RUST_OPTIONS" != "" ]]; then rustc --version; fi
137   - if [[ "$RUST_OPTIONS" != "" ]]; then cargo --version; fi
139 script:
140   - ./autogen.sh
141   - ./configure $RUST_OPTIONS $COVERAGE_OPTIONS --disable-asciidoc --enable-fatal-warnings --disable-silent-rules --enable-fragile-hardening
142   ## We run `make check` because that's what https://jenkins.torproject.org does.
143   - if [[ "$DISTCHECK" == "" ]]; then make check; fi
144   - if [[ "$DISTCHECK" != "" ]]; then make distcheck DISTCHECK_CONFIGURE_FLAGS="$RUST_OPTIONS $COVERAGE_OPTIONS --disable-asciidoc --enable-fatal-warnings --disable-silent-rules --enable-fragile-hardening"; fi
146 after_failure:
147   ## `make check` will leave a log file with more details of test failures.
148   - if [[ "$DISTCHECK" == "" ]]; then cat test-suite.log; fi
149   ## `make distcheck` puts it somewhere different.
150   - if [[ "$DISTCHECK" != "" ]]; then make show-distdir-testlog; fi
152 after_success:
153   ## If this build was one that produced coverage, upload it.
154   - if [[ "$COVERAGE_OPTIONS" != "" ]]; then coveralls -b . --exclude src/test --exclude src/trunnel --gcov-options '\-p'; fi