14 # Images used in testing PR and try-build should be run first.
15 - env: IMAGE=x86_64-gnu-llvm-3.9 RUST_BACKTRACE=1
16 if: type = pull_request OR branch = auto
18 - env: IMAGE=dist-x86_64-linux DEPLOY=1
21 # "alternate" deployments, these are "nightlies" but don't have assertions
22 # turned on, they're deployed to a different location primarily for projects
23 # which are stuck on nightly and don't want llvm assertions in the artifacts
25 - env: IMAGE=dist-x86_64-linux DEPLOY_ALT=1
26 if: branch = try OR branch = auto
28 # FIXME: The macOS dist images are temporarily disabled until Travis bug is fixed
29 # https://github.com/travis-ci/travis-ci/issues/8821
31 RUST_CHECK_TARGET=dist
32 RUST_CONFIGURE_ARGS="--enable-extended --enable-profiler"
35 RUSTC_RETRY_LINKER_ON_SEGFAULT=1
36 SCCACHE_ERROR_LOG=/tmp/sccache.log
37 MACOSX_DEPLOYMENT_TARGET=10.7
44 # macOS builders. These are placed near the beginning because they are very
47 # OSX builders running tests, these run the full test suite.
49 # Note that the compiler is compiled to target 10.8 here because the Xcode
50 # version that we're using, 8.2, cannot compile LLVM for OSX 10.7.
52 RUST_CHECK_TARGET=check
53 RUST_CONFIGURE_ARGS="--build=x86_64-apple-darwin --enable-sanitizers --enable-profiler"
55 RUSTC_RETRY_LINKER_ON_SEGFAULT=1
56 SCCACHE_ERROR_LOG=/tmp/sccache.log
57 MACOSX_DEPLOYMENT_TARGET=10.8
58 MACOSX_STD_DEPLOYMENT_TARGET=10.7
66 RUST_CHECK_TARGET=check
67 RUST_CONFIGURE_ARGS=--build=i686-apple-darwin
69 RUSTC_RETRY_LINKER_ON_SEGFAULT=1
70 SCCACHE_ERROR_LOG=/tmp/sccache.log
71 MACOSX_DEPLOYMENT_TARGET=10.8
72 MACOSX_STD_DEPLOYMENT_TARGET=10.7
79 # OSX builders producing releases. These do not run the full test suite and
80 # just produce a bunch of artifacts.
82 # Note that these are running in the `xcode7` image instead of the
83 # `xcode8.2` image as above. That's because we want to build releases for
84 # OSX 10.7 and `xcode7` is the latest Xcode able to compile LLVM for 10.7.
86 RUST_CHECK_TARGET=dist
87 RUST_CONFIGURE_ARGS="--build=i686-apple-darwin --enable-extended --enable-profiler"
90 RUSTC_RETRY_LINKER_ON_SEGFAULT=1
91 SCCACHE_ERROR_LOG=/tmp/sccache.log
92 MACOSX_DEPLOYMENT_TARGET=10.7
100 RUST_CHECK_TARGET=dist
101 RUST_CONFIGURE_ARGS="--target=aarch64-apple-ios,armv7-apple-ios,armv7s-apple-ios,i386-apple-ios,x86_64-apple-ios --enable-extended --enable-sanitizers --enable-profiler"
104 RUSTC_RETRY_LINKER_ON_SEGFAULT=1
105 SCCACHE_ERROR_LOG=/tmp/sccache.log
106 MACOSX_DEPLOYMENT_TARGET=10.7
108 NO_DEBUG_ASSERTIONS=1
111 if: branch = disabled
113 # Linux builders, remaining docker images
114 - env: IMAGE=arm-android
116 - env: IMAGE=armhf-gnu
118 - env: IMAGE=cross DEPLOY=1
120 - env: IMAGE=cross2 DEPLOY=1
122 - env: IMAGE=dist-aarch64-linux DEPLOY=1
124 - env: IMAGE=dist-android DEPLOY=1
126 - env: IMAGE=dist-arm-linux DEPLOY=1
128 - env: IMAGE=dist-armhf-linux DEPLOY=1
130 - env: IMAGE=dist-armv7-linux DEPLOY=1
132 - env: IMAGE=dist-i586-gnu-i686-musl DEPLOY=1
134 - env: IMAGE=dist-i686-freebsd DEPLOY=1
136 - env: IMAGE=dist-i686-linux DEPLOY=1
138 - env: IMAGE=dist-mips-linux DEPLOY=1
140 - env: IMAGE=dist-mips64-linux DEPLOY=1
142 - env: IMAGE=dist-mips64el-linux DEPLOY=1
144 - env: IMAGE=dist-mipsel-linux DEPLOY=1
146 - env: IMAGE=dist-powerpc-linux DEPLOY=1
148 - env: IMAGE=dist-powerpc64-linux DEPLOY=1
150 - env: IMAGE=dist-powerpc64le-linux DEPLOY=1
152 - env: IMAGE=dist-s390x-linux DEPLOY=1
154 - env: IMAGE=dist-x86_64-freebsd DEPLOY=1
156 - env: IMAGE=dist-x86_64-musl DEPLOY=1
158 - env: IMAGE=dist-x86_64-netbsd DEPLOY=1
162 - env: IMAGE=i686-gnu
164 - env: IMAGE=i686-gnu-nopt
166 - env: IMAGE=wasm32-unknown
168 - env: IMAGE=x86_64-gnu
170 - env: IMAGE=x86_64-gnu-full-bootstrap
172 - env: IMAGE=x86_64-gnu-aux
174 - env: IMAGE=x86_64-gnu-cargotest
176 - env: IMAGE=x86_64-gnu-debug
178 - env: IMAGE=x86_64-gnu-nopt
180 - env: IMAGE=x86_64-gnu-distcheck
182 - env: IMAGE=x86_64-gnu-incremental
187 - SCCACHE_BUCKET=rust-lang-ci-sccache2
188 - SCCACHE_REGION=us-west-1
189 - AWS_ACCESS_KEY_ID=AKIAJAMV3QAMMA6AXHFQ
190 # AWS_SECRET_ACCESS_KEY=...
191 - secure: "j96XxTVOSUf4s4r4htIxn/fvIa5DWbMgLqWl7r8z2QfgUwscmkMXAwXuFNc7s7bGTpV/+CgDiMFFM6BAFLGKutytIF6oA02s9b+usQYnM0th7YQ2AIgm9GtMTJCJp4AoyfFmh8F2faUICBZlfVLUJ34udHEe35vOklix+0k4WDo="
194 - zcat $HOME/docker/rust-ci.tar.gz | docker load || true
195 - mkdir -p $HOME/rustsrc
198 - case "$TRAVIS_OS_NAME" in
200 travis_retry curl -fo $HOME/stamp https://s3-us-west-1.amazonaws.com/rust-lang-ci2/rust-ci-mirror/2017-03-17-stamp-x86_64-unknown-linux-musl &&
201 chmod +x $HOME/stamp &&
202 export PATH=$PATH:$HOME
205 if [[ "$RUST_CHECK_TARGET" == dist ]]; then
206 travis_retry brew update &&
207 travis_retry brew install xz;
209 travis_retry curl -fo /usr/local/bin/sccache https://s3-us-west-1.amazonaws.com/rust-lang-ci2/rust-ci-mirror/2017-05-12-sccache-x86_64-apple-darwin &&
210 chmod +x /usr/local/bin/sccache &&
211 travis_retry curl -fo /usr/local/bin/stamp https://s3-us-west-1.amazonaws.com/rust-lang-ci2/rust-ci-mirror/2017-03-17-stamp-x86_64-apple-darwin &&
212 chmod +x /usr/local/bin/stamp
218 echo "#### Disk usage before running script:";
220 du . | sort -nr | head -n100
222 RUN_SCRIPT="src/ci/init_repo.sh . $HOME/rustsrc";
223 if [ "$TRAVIS_OS_NAME" = "osx" ]; then
224 export RUN_SCRIPT="$RUN_SCRIPT && src/ci/run.sh";
226 export RUN_SCRIPT="$RUN_SCRIPT && src/ci/docker/run.sh $IMAGE";
229 # Log time information from this machine and an external machine for insight into possible
230 # clock drift. Timezones don't matter since relative deltas give all the necessary info.
233 date && (curl -fs --head https://google.com | grep ^Date: | sed 's/Date: //g' || true)
234 - stamp sh -x -c "$RUN_SCRIPT"
236 date && (curl -fs --head https://google.com | grep ^Date: | sed 's/Date: //g' || true)
240 echo "#### Build successful; Disk usage after running script:";
242 du . | sort -nr | head -n100
246 echo "#### Build failed; Disk usage after running script:";
248 du . | sort -nr | head -n100
250 # One of these is the linux sccache log, one is the OSX sccache log. Instead
251 # of worrying about what system we are just cat both. One of these commands
252 # will fail but that's ok, they'll both get executed.
253 - cat obj/tmp/sccache.log
254 - cat /tmp/sccache.log
256 # Random attempt at debugging currently. Just poking around in here to see if
258 - ls -lat $HOME/Library/Logs/DiagnosticReports/
259 - find $HOME/Library/Logs/DiagnosticReports
261 -not -name '*.stage2-*.crash'
262 -not -name 'com.apple.CoreSimulator.CoreSimulatorService-*.crash'
263 -exec printf travis_fold":start:crashlog\n\033[31;1m%s\033[0m\n" {} \;
264 -exec head -750 {} \;
265 -exec echo travis_fold":"end:crashlog \;
267 # attempt to debug anything killed by the oom killer on linux, just to see if
269 - dmesg | grep -i kill
271 # Save tagged docker images we created and load them if they're available
272 # Travis saves caches whether the build failed or not, nuke rustsrc if
273 # the failure was while updating it (as it may be in a bad state)
274 # https://github.com/travis-ci/travis-ci/issues/4472
276 - docker history -q rust-ci |
279 gzip > $HOME/docker/rust-ci.tar.gz
289 - mkdir -p deploy/$TRAVIS_COMMIT
291 if [ "$TRAVIS_OS_NAME" == "osx" ]; then
292 rm -rf build/dist/doc &&
293 cp -r build/dist/* deploy/$TRAVIS_COMMIT;
295 rm -rf obj/build/dist/doc &&
296 cp -r obj/build/dist/* deploy/$TRAVIS_COMMIT;
298 - travis_retry gem update --system
302 bucket: rust-lang-ci2
305 upload_dir: rustc-builds
308 access_key_id: AKIAJVBODR3IA4O72THQ
310 secure: "kUGd3t7JcVWFESgIlzvsM8viZgCA9Encs3creW0xLJaLSeI1iVjlJK4h/2/nO6y224AFrh/GUfsNr4/4AlxPuYb8OU5oC5Lv+Ff2JiRDYtuNpyQSKAQp+bRYytWMtrmhja91h118Mbm90cUfcLPwkdiINgJNTXhPKg5Cqu3VYn0="
313 condition: $DEPLOY = 1
316 bucket: rust-lang-ci2
319 upload_dir: rustc-builds-try
322 access_key_id: AKIAJVBODR3IA4O72THQ
324 secure: "kUGd3t7JcVWFESgIlzvsM8viZgCA9Encs3creW0xLJaLSeI1iVjlJK4h/2/nO6y224AFrh/GUfsNr4/4AlxPuYb8OU5oC5Lv+Ff2JiRDYtuNpyQSKAQp+bRYytWMtrmhja91h118Mbm90cUfcLPwkdiINgJNTXhPKg5Cqu3VYn0="
327 condition: $DEPLOY_ALT = 1
329 # this is the same as the above deployment provider except that it uploads to
330 # a slightly different directory and has a different trigger
332 bucket: rust-lang-ci2
335 upload_dir: rustc-builds-alt
338 access_key_id: AKIAJVBODR3IA4O72THQ
340 secure: "kUGd3t7JcVWFESgIlzvsM8viZgCA9Encs3creW0xLJaLSeI1iVjlJK4h/2/nO6y224AFrh/GUfsNr4/4AlxPuYb8OU5oC5Lv+Ff2JiRDYtuNpyQSKAQp+bRYytWMtrmhja91h118Mbm90cUfcLPwkdiINgJNTXhPKg5Cqu3VYn0="
343 condition: $DEPLOY_ALT = 1