14 # Images used in testing PR and try-build should be run first.
15 - env: IMAGE=x86_64-gnu-llvm-3.7 ALLOW_PR=1 RUST_BACKTRACE=1
16 - env: IMAGE=dist-x86_64-linux DEPLOY=1 ALLOW_TRY=1
18 # "alternate" deployments, these are "nightlies" but don't have assertions
19 # turned on, they're deployed to a different location primarily for projects
20 # which are stuck on nightly and don't want llvm assertions in the artifacts
22 - env: IMAGE=dist-x86_64-linux DEPLOY_ALT=1
24 RUST_CHECK_TARGET=dist
25 RUST_CONFIGURE_ARGS="--enable-extended --enable-profiler"
28 RUSTC_RETRY_LINKER_ON_SEGFAULT=1
29 SCCACHE_ERROR_LOG=/tmp/sccache.log
30 MACOSX_DEPLOYMENT_TARGET=10.7
34 # macOS builders. These are placed near the beginning because they are very
37 # OSX builders running tests, these run the full test suite.
39 # Note that the compiler is compiled to target 10.8 here because the Xcode
40 # version that we're using, 8.2, cannot compile LLVM for OSX 10.7.
42 RUST_CHECK_TARGET=check
43 RUST_CONFIGURE_ARGS="--build=x86_64-apple-darwin --enable-sanitizers --enable-profiler"
45 RUSTC_RETRY_LINKER_ON_SEGFAULT=1
46 SCCACHE_ERROR_LOG=/tmp/sccache.log
47 MACOSX_DEPLOYMENT_TARGET=10.8
48 MACOSX_STD_DEPLOYMENT_TARGET=10.7
52 RUST_CHECK_TARGET=check
53 RUST_CONFIGURE_ARGS=--build=i686-apple-darwin
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
62 # OSX builders producing releases. These do not run the full test suite and
63 # just produce a bunch of artifacts.
65 # Note that these are running in the `xcode7` image instead of the
66 # `xcode8.2` image as above. That's because we want to build releases for
67 # OSX 10.7 and `xcode7` is the latest Xcode able to compile LLVM for 10.7.
69 RUST_CHECK_TARGET=dist
70 RUST_CONFIGURE_ARGS="--build=i686-apple-darwin --enable-extended --enable-profiler"
73 RUSTC_RETRY_LINKER_ON_SEGFAULT=1
74 SCCACHE_ERROR_LOG=/tmp/sccache.log
75 MACOSX_DEPLOYMENT_TARGET=10.7
79 RUST_CHECK_TARGET=dist
80 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"
83 RUSTC_RETRY_LINKER_ON_SEGFAULT=1
84 SCCACHE_ERROR_LOG=/tmp/sccache.log
85 MACOSX_DEPLOYMENT_TARGET=10.7
89 # Linux builders, remaining docker images
90 - env: IMAGE=arm-android
91 - env: IMAGE=armhf-gnu
92 - env: IMAGE=cross DEPLOY=1
93 - env: IMAGE=dist-aarch64-linux DEPLOY=1
94 - env: IMAGE=dist-android DEPLOY=1
95 - env: IMAGE=dist-arm-linux DEPLOY=1
96 - env: IMAGE=dist-armhf-linux DEPLOY=1
97 - env: IMAGE=dist-armv7-linux DEPLOY=1
98 - env: IMAGE=dist-fuchsia DEPLOY=1
99 - env: IMAGE=dist-i586-gnu-i686-musl DEPLOY=1
100 - env: IMAGE=dist-i686-freebsd DEPLOY=1
101 - env: IMAGE=dist-i686-linux DEPLOY=1
102 - env: IMAGE=dist-mips-linux DEPLOY=1
103 - env: IMAGE=dist-mips64-linux DEPLOY=1
104 - env: IMAGE=dist-mips64el-linux DEPLOY=1
105 - env: IMAGE=dist-mipsel-linux DEPLOY=1
106 - env: IMAGE=dist-powerpc-linux DEPLOY=1
107 - env: IMAGE=dist-powerpc64-linux DEPLOY=1
108 - env: IMAGE=dist-powerpc64le-linux DEPLOY=1
109 - env: IMAGE=dist-s390x-linux DEPLOY=1
110 - env: IMAGE=dist-x86_64-freebsd DEPLOY=1
111 - env: IMAGE=dist-x86_64-musl DEPLOY=1
112 - env: IMAGE=dist-x86_64-netbsd DEPLOY=1
114 - env: IMAGE=i686-gnu
115 - env: IMAGE=i686-gnu-nopt
116 # - env: IMAGE=wasm32 issue 42646
117 - env: IMAGE=x86_64-gnu
118 - env: IMAGE=x86_64-gnu-full-bootstrap
119 - env: IMAGE=x86_64-gnu-aux
120 - env: IMAGE=x86_64-gnu-debug
121 - env: IMAGE=x86_64-gnu-nopt
122 - env: IMAGE=x86_64-gnu-distcheck
123 - env: IMAGE=x86_64-gnu-incremental
127 - SCCACHE_BUCKET=rust-lang-ci-sccache
128 - AWS_ACCESS_KEY_ID=AKIAJAMV3QAMMA6AXHFQ
129 # AWS_SECRET_ACCESS_KEY=...
130 - secure: "j96XxTVOSUf4s4r4htIxn/fvIa5DWbMgLqWl7r8z2QfgUwscmkMXAwXuFNc7s7bGTpV/+CgDiMFFM6BAFLGKutytIF6oA02s9b+usQYnM0th7YQ2AIgm9GtMTJCJp4AoyfFmh8F2faUICBZlfVLUJ34udHEe35vOklix+0k4WDo="
133 # If we are building a pull request, do the build if $ALLOW_PR == 1
134 # Otherwise, do the build if we are on the auto branch, or the try branch and $ALLOW_TRY == 1
136 if [[ "$TRAVIS_PULL_REQUEST" != "false" ]]; then
137 if [[ "$ALLOW_PR" == "1" ]]; then
138 export SKIP_BUILD=false;
140 export SKIP_BUILD=true;
142 elif [[ "$TRAVIS_BRANCH" == "auto" || ( "$ALLOW_TRY" == "1" && "$TRAVIS_BRANCH" == "try" ) ]]; then
143 export SKIP_BUILD=false;
145 export SKIP_BUILD=true;
148 if [[ "$SKIP_BUILD" == false ]]; then
149 zcat $HOME/docker/rust-ci.tar.gz | docker load || true
151 - mkdir -p $HOME/rustsrc
155 if [[ "$SKIP_BUILD" == true ]]; then
156 echo echo skipping, not a full build > $HOME/stamp &&
157 chmod +x $HOME/stamp &&
158 export PATH=$PATH:$HOME;
160 case "$TRAVIS_OS_NAME" in
162 travis_retry curl -fo $HOME/stamp https://s3.amazonaws.com/rust-lang-ci/rust-ci-mirror/2017-03-17-stamp-x86_64-unknown-linux-musl &&
163 chmod +x $HOME/stamp &&
164 export PATH=$PATH:$HOME
167 if [[ "$RUST_CHECK_TARGET" == dist ]]; then
168 travis_retry brew update &&
169 travis_retry brew install xz;
171 travis_retry curl -fo /usr/local/bin/sccache https://s3.amazonaws.com/rust-lang-ci/rust-ci-mirror/2017-05-12-sccache-x86_64-apple-darwin &&
172 chmod +x /usr/local/bin/sccache &&
173 travis_retry curl -fo /usr/local/bin/stamp https://s3.amazonaws.com/rust-lang-ci/rust-ci-mirror/2017-03-17-stamp-x86_64-apple-darwin &&
174 chmod +x /usr/local/bin/stamp
181 echo "#### Disk usage before running script:";
183 du . | sort -nr | head -n100
185 RUN_SCRIPT="src/ci/init_repo.sh . $HOME/rustsrc";
186 if [ "$TRAVIS_OS_NAME" = "osx" ]; then
187 export RUN_SCRIPT="$RUN_SCRIPT && src/ci/run.sh";
189 export RUN_SCRIPT="$RUN_SCRIPT && src/ci/docker/run.sh $IMAGE";
192 # Log time information from this machine and an external machine for insight into possible
193 # clock drift. Timezones don't matter since relative deltas give all the necessary info.
196 date && (curl -fs --head https://google.com | grep ^Date: | sed 's/Date: //g' || true)
197 - stamp sh -x -c "$RUN_SCRIPT"
199 date && (curl -fs --head https://google.com | grep ^Date: | sed 's/Date: //g' || true)
203 echo "#### Build successful; Disk usage after running script:";
205 du . | sort -nr | head -n100
209 echo "#### Build failed; Disk usage after running script:";
211 du . | sort -nr | head -n100
213 # One of these is the linux sccache log, one is the OSX sccache log. Instead
214 # of worrying about what system we are just cat both. One of these commands
215 # will fail but that's ok, they'll both get executed.
216 - cat obj/tmp/sccache.log
217 - cat /tmp/sccache.log
219 # Random attempt at debugging currently. Just poking around in here to see if
221 - ls $HOME/Library/Logs/DiagnosticReports/
223 # attempt to debug anything killed by the oom killer on linux, just to see if
225 - dmesg | grep -i kill
227 # Save tagged docker images we created and load them if they're available
228 # Travis saves caches whether the build failed or not, nuke rustsrc if
229 # the failure was while updating it (as it may be in a bad state)
230 # https://github.com/travis-ci/travis-ci/issues/4472
232 - docker history -q rust-ci |
235 gzip > $HOME/docker/rust-ci.tar.gz
245 - mkdir -p deploy/$TRAVIS_COMMIT
247 if [ "$TRAVIS_OS_NAME" == "osx" ]; then
248 rm -rf build/dist/doc &&
249 cp -r build/dist/* deploy/$TRAVIS_COMMIT;
251 rm -rf obj/build/dist/doc &&
252 cp -r obj/build/dist/* deploy/$TRAVIS_COMMIT;
260 upload_dir: rustc-builds
263 access_key_id: AKIAJVBODR3IA4O72THQ
265 secure: "kUGd3t7JcVWFESgIlzvsM8viZgCA9Encs3creW0xLJaLSeI1iVjlJK4h/2/nO6y224AFrh/GUfsNr4/4AlxPuYb8OU5oC5Lv+Ff2JiRDYtuNpyQSKAQp+bRYytWMtrmhja91h118Mbm90cUfcLPwkdiINgJNTXhPKg5Cqu3VYn0="
268 condition: $DEPLOY = 1
274 upload_dir: rustc-builds-try
277 access_key_id: AKIAJVBODR3IA4O72THQ
279 secure: "kUGd3t7JcVWFESgIlzvsM8viZgCA9Encs3creW0xLJaLSeI1iVjlJK4h/2/nO6y224AFrh/GUfsNr4/4AlxPuYb8OU5oC5Lv+Ff2JiRDYtuNpyQSKAQp+bRYytWMtrmhja91h118Mbm90cUfcLPwkdiINgJNTXhPKg5Cqu3VYn0="
282 condition: $DEPLOY = 1 && $ALLOW_TRY = 1
284 # this is the same as the above deployment provider except that it uploads to
285 # a slightly different directory and has a different trigger
290 upload_dir: rustc-builds-alt
293 access_key_id: AKIAJVBODR3IA4O72THQ
295 secure: "kUGd3t7JcVWFESgIlzvsM8viZgCA9Encs3creW0xLJaLSeI1iVjlJK4h/2/nO6y224AFrh/GUfsNr4/4AlxPuYb8OU5oC5Lv+Ff2JiRDYtuNpyQSKAQp+bRYytWMtrmhja91h118Mbm90cUfcLPwkdiINgJNTXhPKg5Cqu3VYn0="
298 condition: $DEPLOY_ALT = 1