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
19 if: branch = try OR branch = auto
21 # "alternate" deployments, these are "nightlies" but have LLVM assertions
22 # turned on, they're deployed to a different location primarily for
24 - env: IMAGE=dist-x86_64-linux DEPLOY_ALT=1
25 if: branch = try OR branch = auto
28 RUST_CHECK_TARGET=dist
29 RUST_CONFIGURE_ARGS="--enable-extended --enable-profiler"
32 RUSTC_RETRY_LINKER_ON_SEGFAULT=1
33 SCCACHE_ERROR_LOG=/tmp/sccache.log
34 MACOSX_DEPLOYMENT_TARGET=10.7
38 osx_image: xcode9.3-moar
41 # macOS builders. These are placed near the beginning because they are very
44 # OSX builders running tests, these run the full test suite.
46 # Note that the compiler is compiled to target 10.8 here because the Xcode
47 # version that we're using, 8.2, cannot compile LLVM for OSX 10.7.
49 RUST_CHECK_TARGET=check
50 RUST_CONFIGURE_ARGS="--build=x86_64-apple-darwin --enable-sanitizers --enable-profiler"
52 RUSTC_RETRY_LINKER_ON_SEGFAULT=1
53 SCCACHE_ERROR_LOG=/tmp/sccache.log
54 MACOSX_DEPLOYMENT_TARGET=10.8
55 MACOSX_STD_DEPLOYMENT_TARGET=10.7
59 osx_image: xcode9.3-moar
63 RUST_CHECK_TARGET=check
64 RUST_CONFIGURE_ARGS=--build=i686-apple-darwin
66 RUSTC_RETRY_LINKER_ON_SEGFAULT=1
67 SCCACHE_ERROR_LOG=/tmp/sccache.log
68 MACOSX_DEPLOYMENT_TARGET=10.8
69 MACOSX_STD_DEPLOYMENT_TARGET=10.7
73 osx_image: xcode9.3-moar
76 # OSX builders producing releases. These do not run the full test suite and
77 # just produce a bunch of artifacts.
79 # Note that these are running in the `xcode7` image instead of the
80 # `xcode8.2` image as above. That's because we want to build releases for
81 # OSX 10.7 and `xcode7` is the latest Xcode able to compile LLVM for 10.7.
83 RUST_CHECK_TARGET=dist
84 RUST_CONFIGURE_ARGS="--build=i686-apple-darwin --enable-full-tools --enable-profiler"
87 RUSTC_RETRY_LINKER_ON_SEGFAULT=1
88 SCCACHE_ERROR_LOG=/tmp/sccache.log
89 MACOSX_DEPLOYMENT_TARGET=10.7
93 osx_image: xcode9.3-moar
97 RUST_CHECK_TARGET=dist
98 RUST_CONFIGURE_ARGS="--target=aarch64-apple-ios,armv7-apple-ios,armv7s-apple-ios,i386-apple-ios,x86_64-apple-ios --enable-full-tools --enable-sanitizers --enable-profiler"
101 RUSTC_RETRY_LINKER_ON_SEGFAULT=1
102 SCCACHE_ERROR_LOG=/tmp/sccache.log
103 MACOSX_DEPLOYMENT_TARGET=10.7
105 NO_DEBUG_ASSERTIONS=1
107 osx_image: xcode9.3-moar
110 # Linux builders, remaining docker images
111 - env: IMAGE=arm-android
113 - env: IMAGE=armhf-gnu
115 - env: IMAGE=dist-various-1 DEPLOY=1
117 - env: IMAGE=dist-various-2 DEPLOY=1
119 - env: IMAGE=dist-various-3 DEPLOY=1
121 - env: IMAGE=dist-aarch64-linux DEPLOY=1
123 - env: IMAGE=dist-android DEPLOY=1
125 - env: IMAGE=dist-arm-linux DEPLOY=1
127 - env: IMAGE=dist-armhf-linux DEPLOY=1
129 - env: IMAGE=dist-armv7-linux DEPLOY=1
131 - env: IMAGE=dist-i586-gnu-i586-i686-musl DEPLOY=1
133 - env: IMAGE=dist-i686-freebsd DEPLOY=1
135 - env: IMAGE=dist-i686-linux DEPLOY=1
137 - env: IMAGE=dist-mips-linux DEPLOY=1
139 - env: IMAGE=dist-mips64-linux DEPLOY=1
141 - env: IMAGE=dist-mips64el-linux DEPLOY=1
143 - env: IMAGE=dist-mipsel-linux DEPLOY=1
145 - env: IMAGE=dist-powerpc-linux DEPLOY=1
147 - env: IMAGE=dist-powerpc64-linux DEPLOY=1
149 - env: IMAGE=dist-powerpc64le-linux DEPLOY=1
151 - env: IMAGE=dist-s390x-linux DEPLOY=1
153 - env: IMAGE=dist-x86_64-freebsd DEPLOY=1
155 - env: IMAGE=dist-x86_64-musl DEPLOY=1
157 - env: IMAGE=dist-x86_64-netbsd DEPLOY=1
161 - env: IMAGE=i686-gnu
163 - env: IMAGE=i686-gnu-nopt
165 - env: IMAGE=wasm32-unknown
167 - env: IMAGE=x86_64-gnu
169 - env: IMAGE=x86_64-gnu-full-bootstrap
171 - env: IMAGE=x86_64-gnu-aux
173 - env: IMAGE=x86_64-gnu-tools
175 - env: IMAGE=x86_64-gnu-debug
177 - env: IMAGE=x86_64-gnu-nopt
179 - env: IMAGE=x86_64-gnu-distcheck
181 - env: IMAGE=x86_64-gnu-incremental
184 - stage: publish toolstate
185 if: branch = master AND type = push
190 MESSAGE_FILE=$(mktemp -t msg.XXXXXX);
191 . src/ci/docker/x86_64-gnu-tools/repo.sh;
192 commit_toolstate_change "$MESSAGE_FILE" "$TRAVIS_BUILD_DIR/src/tools/publish_toolstate.py" "$(git rev-parse HEAD)" "$(git log --format=%s -n1 HEAD)" "$MESSAGE_FILE" "$TOOLSTATE_REPO_ACCESS_TOKEN";
196 - SCCACHE_BUCKET=rust-lang-ci-sccache2
197 - SCCACHE_REGION=us-west-1
198 - AWS_ACCESS_KEY_ID=AKIAJAMV3QAMMA6AXHFQ
199 # AWS_SECRET_ACCESS_KEY=...
200 - secure: "j96XxTVOSUf4s4r4htIxn/fvIa5DWbMgLqWl7r8z2QfgUwscmkMXAwXuFNc7s7bGTpV/+CgDiMFFM6BAFLGKutytIF6oA02s9b+usQYnM0th7YQ2AIgm9GtMTJCJp4AoyfFmh8F2faUICBZlfVLUJ34udHEe35vOklix+0k4WDo="
201 # TOOLSTATE_REPO_ACCESS_TOKEN=...
202 - secure: "cFh8thThqEJLC98XKI5pfqflUzOlxsYPRW20AWRaYOOgYHPTiGWypTXiPbGSKaeAXTZoOA+DpQtEmefc0U6lt9dHc7a/MIaK6isFurjlnKYiLOeTruzyu1z7PWCeZ/jKXsU2RK/88DBtlNwfMdaMIeuKj14IVfpepPPL71ETbuk="
205 # We'll use the AWS cli to download/upload cached docker layers, so install
207 - if [ "$TRAVIS_OS_NAME" = linux ]; then
208 pip install --user awscli;
209 export PATH=$PATH:$HOME/.local/bin;
211 - mkdir -p $HOME/rustsrc
212 # FIXME(#46924): these two commands are required to enable IPv6,
213 # they shouldn't exist, please revert once more official solutions appeared.
214 # see https://github.com/travis-ci/travis-ci/issues/8891#issuecomment-353403729
215 - if [ "$TRAVIS_OS_NAME" = linux ]; then
216 echo '{"ipv6":true,"fixed-cidr-v6":"fd9a:8454:6789:13f7::/64"}' | sudo tee /etc/docker/daemon.json;
217 sudo service docker restart;
221 - case "$TRAVIS_OS_NAME" in
223 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 &&
224 chmod +x $HOME/stamp &&
225 export PATH=$PATH:$HOME
228 if [[ "$RUST_CHECK_TARGET" == dist ]]; then
229 travis_retry brew update &&
230 travis_retry brew install xz;
232 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 &&
233 chmod +x /usr/local/bin/sccache &&
234 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 &&
235 chmod +x /usr/local/bin/stamp
241 echo "#### Disk usage before running script:";
243 du . | sort -nr | head -n100
245 RUN_SCRIPT="src/ci/init_repo.sh . $HOME/rustsrc";
246 if [ "$TRAVIS_OS_NAME" = "osx" ]; then
247 export RUN_SCRIPT="$RUN_SCRIPT && src/ci/run.sh";
249 export RUN_SCRIPT="$RUN_SCRIPT && src/ci/docker/run.sh $IMAGE";
252 # Log time information from this machine and an external machine for insight into possible
253 # clock drift. Timezones don't matter since relative deltas give all the necessary info.
256 date && (curl -fs --head https://google.com | grep ^Date: | sed 's/Date: //g' || true)
257 - stamp sh -x -c "$RUN_SCRIPT"
259 date && (curl -fs --head https://google.com | grep ^Date: | sed 's/Date: //g' || true)
263 echo "#### Build successful; Disk usage after running script:";
265 du . | sort -nr | head -n100
269 echo "#### Build failed; Disk usage after running script:";
271 du . | sort -nr | head -n100
273 # One of these is the linux sccache log, one is the OSX sccache log. Instead
274 # of worrying about what system we are just cat both. One of these commands
275 # will fail but that's ok, they'll both get executed.
276 - cat obj/tmp/sccache.log
277 - cat /tmp/sccache.log
279 # Random attempt at debugging currently. Just poking around in here to see if
281 - ls -lat $HOME/Library/Logs/DiagnosticReports/
282 - find $HOME/Library/Logs/DiagnosticReports
285 -not -name '*.stage2-*.crash'
286 -not -name 'com.apple.CoreSimulator.CoreSimulatorService-*.crash'
287 -exec printf travis_fold":start:crashlog\n\033[31;1m%s\033[0m\n" {} \;
288 -exec head -750 {} \;
289 -exec echo travis_fold":"end:crashlog \; || true
291 # attempt to debug anything killed by the oom killer on linux, just to see if
293 - dmesg | grep -i kill
299 - mkdir -p deploy/$TRAVIS_COMMIT
301 if [ "$TRAVIS_OS_NAME" == "osx" ]; then
302 rm -rf build/dist/doc &&
303 cp -r build/dist/* deploy/$TRAVIS_COMMIT;
305 rm -rf obj/build/dist/doc &&
306 cp -r obj/build/dist/* deploy/$TRAVIS_COMMIT;
308 - travis_retry gem update --system
309 - ls -la deploy/$TRAVIS_COMMIT
313 bucket: rust-lang-ci2
316 upload_dir: rustc-builds
319 access_key_id: AKIAJVBODR3IA4O72THQ
321 secure: "kUGd3t7JcVWFESgIlzvsM8viZgCA9Encs3creW0xLJaLSeI1iVjlJK4h/2/nO6y224AFrh/GUfsNr4/4AlxPuYb8OU5oC5Lv+Ff2JiRDYtuNpyQSKAQp+bRYytWMtrmhja91h118Mbm90cUfcLPwkdiINgJNTXhPKg5Cqu3VYn0="
324 condition: $DEPLOY = 1
326 # this is the same as the above deployment provider except that it uploads to
327 # a slightly different directory and has a different trigger
329 bucket: rust-lang-ci2
332 upload_dir: rustc-builds-alt
335 access_key_id: AKIAJVBODR3IA4O72THQ
337 secure: "kUGd3t7JcVWFESgIlzvsM8viZgCA9Encs3creW0xLJaLSeI1iVjlJK4h/2/nO6y224AFrh/GUfsNr4/4AlxPuYb8OU5oC5Lv+Ff2JiRDYtuNpyQSKAQp+bRYytWMtrmhja91h118Mbm90cUfcLPwkdiINgJNTXhPKg5Cqu3VYn0="
340 condition: $DEPLOY_ALT = 1
342 # These two providers are the same as the two above, except deploy on the
343 # try branch. Travis does not appear to provide a way to use "or" in these
346 bucket: rust-lang-ci2
349 upload_dir: rustc-builds
352 access_key_id: AKIAJVBODR3IA4O72THQ
354 secure: "kUGd3t7JcVWFESgIlzvsM8viZgCA9Encs3creW0xLJaLSeI1iVjlJK4h/2/nO6y224AFrh/GUfsNr4/4AlxPuYb8OU5oC5Lv+Ff2JiRDYtuNpyQSKAQp+bRYytWMtrmhja91h118Mbm90cUfcLPwkdiINgJNTXhPKg5Cqu3VYn0="
357 condition: $DEPLOY = 1
360 bucket: rust-lang-ci2
363 upload_dir: rustc-builds-alt
366 access_key_id: AKIAJVBODR3IA4O72THQ
368 secure: "kUGd3t7JcVWFESgIlzvsM8viZgCA9Encs3creW0xLJaLSeI1iVjlJK4h/2/nO6y224AFrh/GUfsNr4/4AlxPuYb8OU5oC5Lv+Ff2JiRDYtuNpyQSKAQp+bRYytWMtrmhja91h118Mbm90cUfcLPwkdiINgJNTXhPKg5Cqu3VYn0="
371 condition: $DEPLOY_ALT = 1