1 ######################################################
2 # WARNING! Action needed when changing this file #
3 ######################################################
5 # Due to GitHub Actions limitations, we can't use YAML Anchors directly in the
6 # CI configuration stored on the repository. To work around that this file is
7 # expanded by a tool in the repository, and the expansion is committed as well.
9 # After you make any change to the file you'll need to run this command:
11 # ./x.py run src/tools/expand-yaml-anchors
13 # ...and commit the file it updated in addition to this one. If you forget this
18 ###############################
19 # YAML Anchors Definition #
20 ###############################
22 # This key contains most of the YAML anchors that will be used later in the
23 # document. YAML anchors allows us to greatly reduce duplication inside the CI
24 # configuration by reusing parts of the configuration.
26 # YAML anchors work by defining an anchor with `&anchor-name` and reusing its
27 # content in another place with `*anchor-name`. The special `<<` map key merges
28 # the content of the map with the content of the anchor (or list of anchors).
30 # The expand-yaml-anchors tool will automatically remove this block from the
32 x--expand-yaml-anchors--remove:
34 - &shared-ci-variables
35 CI_JOB_NAME: ${{ matrix.name }}
38 SCCACHE_BUCKET: rust-lang-ci-sccache2
39 TOOLSTATE_REPO: https://github.com/rust-lang-nursery/rust-toolstate
40 CACHE_DOMAIN: ci-caches.rust-lang.org
43 SCCACHE_BUCKET: rust-lang-ci-sccache2
44 DEPLOY_BUCKET: rust-lang-ci2
45 TOOLSTATE_REPO: https://github.com/rust-lang-nursery/rust-toolstate
46 TOOLSTATE_ISSUES_API_URL: https://api.github.com/repos/rust-lang/rust/issues
48 # AWS_SECRET_ACCESS_KEYs are stored in GitHub's secrets storage, named
49 # AWS_SECRET_ACCESS_KEY_<keyid>. Including the key id in the name allows to
50 # rotate them in a single branch while keeping the old key in another
51 # branch, which wouldn't be possible if the key was named with the kind
52 # (caches, artifacts...).
53 CACHES_AWS_ACCESS_KEY_ID: AKIA46X5W6CZI5DHEBFL
54 ARTIFACTS_AWS_ACCESS_KEY_ID: AKIA46X5W6CZN24CBO55
55 CACHE_DOMAIN: ci-caches.rust-lang.org
58 SCCACHE_BUCKET: rust-lang-gha-caches
59 DEPLOY_BUCKET: rust-lang-gha
60 TOOLSTATE_REPO: https://github.com/pietroalbini/rust-toolstate
61 TOOLSTATE_ISSUES_API_URL: https://api.github.com/repos/pietroalbini/rust-toolstate/issues
63 # AWS_SECRET_ACCESS_KEYs are stored in GitHub's secrets storage, named
64 # AWS_SECRET_ACCESS_KEY_<keyid>. Including the key id in the name allows to
65 # rotate them in a single branch while keeping the old key in another
66 # branch, which wouldn't be possible if the key was named with the kind
67 # (caches, artifacts...).
68 CACHES_AWS_ACCESS_KEY_ID: AKIA46X5W6CZOMUQATD5
69 ARTIFACTS_AWS_ACCESS_KEY_ID: AKIA46X5W6CZH5AYXDVF
70 CACHE_DOMAIN: ci-caches-gha.rust-lang.org
80 os: macos-latest # We don't have an XL builder for this
88 os: [self-hosted, ARM64, linux]
91 if: success() && !env.SKIP_JOB
95 runs-on: "${{ matrix.os }}"
96 env: *shared-ci-variables
98 - name: disable git crlf conversion
99 run: git config --global core.autocrlf false
101 - name: checkout the source code
102 uses: actions/checkout@v3
106 # Rust Log Analyzer can't currently detect the PR number of a GitHub
107 # Actions build on its own, so a hint in the log message is needed to
108 # point it in the right direction.
109 - name: configure the PR in which the error message will be posted
110 run: echo "[CI_PR_NUMBER=$num]"
112 num: ${{ github.event.number }}
113 if: success() && !env.SKIP_JOB && github.event_name == 'pull_request'
115 - name: add extra environment variables
116 run: src/ci/scripts/setup-environment.sh
118 # Since it's not possible to merge `${{ matrix.env }}` with the other
119 # variables in `job.<name>.env`, the variables defined in the matrix
120 # are passed to the `setup-environment.sh` script encoded in JSON,
121 # which then uses log commands to actually set them.
122 EXTRA_VARIABLES: ${{ toJson(matrix.env) }}
125 - name: decide whether to skip this job
126 run: src/ci/scripts/should-skip-this.sh
129 - name: ensure the channel matches the target branch
130 run: src/ci/scripts/verify-channel.sh
133 - name: configure GitHub Actions to kill the build when outdated
134 uses: rust-lang/simpleinfra/github-actions/cancel-outdated-builds@master
136 github_token: "${{ secrets.github_token }}"
137 if: success() && !env.SKIP_JOB && github.ref != 'refs/heads/try'
140 - name: collect CPU statistics
141 run: src/ci/scripts/collect-cpu-stats.sh
144 - name: show the current environment
145 run: src/ci/scripts/dump-environment.sh
148 - name: install awscli
149 run: src/ci/scripts/install-awscli.sh
152 - name: install sccache
153 run: src/ci/scripts/install-sccache.sh
156 - name: install clang
157 run: src/ci/scripts/install-clang.sh
161 run: src/ci/scripts/install-wix.sh
164 - name: disable git crlf conversion
165 run: src/ci/scripts/disable-git-crlf-conversion.sh
168 - name: checkout submodules
169 run: src/ci/scripts/checkout-submodules.sh
172 - name: install MSYS2
173 run: src/ci/scripts/install-msys2.sh
176 - name: install MinGW
177 run: src/ci/scripts/install-mingw.sh
180 - name: install ninja
181 run: src/ci/scripts/install-ninja.sh
184 - name: enable ipv6 on Docker
185 run: src/ci/scripts/enable-docker-ipv6.sh
188 # Disable automatic line ending conversion (again). On Windows, when we're
189 # installing dependencies, something switches the git configuration directory or
190 # re-enables autocrlf. We've not tracked down the exact cause -- and there may
191 # be multiple -- but this should ensure submodules are checked out with the
192 # appropriate line endings.
193 - name: disable git crlf conversion
194 run: src/ci/scripts/disable-git-crlf-conversion.sh
197 - name: ensure line endings are correct
198 run: src/ci/scripts/verify-line-endings.sh
201 - name: ensure backported commits are in upstream branches
202 run: src/ci/scripts/verify-backported-commits.sh
205 - name: ensure the stable version number is correct
206 run: src/ci/scripts/verify-stable-version-number.sh
209 - name: run the build
210 run: src/ci/scripts/run-build-from-ci.sh
212 AWS_ACCESS_KEY_ID: ${{ env.CACHES_AWS_ACCESS_KEY_ID }}
213 AWS_SECRET_ACCESS_KEY: ${{ secrets[format('AWS_SECRET_ACCESS_KEY_{0}', env.CACHES_AWS_ACCESS_KEY_ID)] }}
214 TOOLSTATE_REPO_ACCESS_TOKEN: ${{ secrets.TOOLSTATE_REPO_ACCESS_TOKEN }}
217 - name: upload artifacts to S3
218 run: src/ci/scripts/upload-artifacts.sh
220 AWS_ACCESS_KEY_ID: ${{ env.ARTIFACTS_AWS_ACCESS_KEY_ID }}
221 AWS_SECRET_ACCESS_KEY: ${{ secrets[format('AWS_SECRET_ACCESS_KEY_{0}', env.ARTIFACTS_AWS_ACCESS_KEY_ID)] }}
222 # Adding a condition on DEPLOY=1 or DEPLOY_ALT=1 is not needed as all deploy
223 # builders *should* have the AWS credentials available. Still, explicitly
224 # adding the condition is helpful as this way CI will not silently skip
225 # deploying artifacts from a dist builder if the variables are misconfigured,
226 # erroring about invalid credentials instead.
227 if: success() && !env.SKIP_JOB && (github.event_name == 'push' || env.DEPLOY == '1' || env.DEPLOY_ALT == '1')
230 # These snippets are used by the try-success, try-failure, auto-success and auto-failure jobs.
231 # Check out their documentation for more information on why they're needed.
234 name: bors build finished
235 runs-on: ubuntu-latest
239 - name: mark the job as a success
242 <<: *base-outcome-job
246 - name: mark the job as a failure
249 <<: *base-outcome-job
251 ###########################
252 # Builders definition #
253 ###########################
269 # On Linux, macOS, and Windows, use the system-provided bash as the default
270 # shell. (This should only make a difference on Windows, where the default
271 # shell is PowerShell.)
279 <<: [*shared-ci-variables, *public-variables]
280 if: github.event_name == 'pull_request'
287 - name: x86_64-gnu-llvm-12
290 - name: x86_64-gnu-llvm-12-stage1
293 - name: x86_64-gnu-tools
295 CI_ONLY_WHEN_SUBMODULES_CHANGED: 1
302 <<: [*shared-ci-variables, *prod-variables]
303 if: github.event_name == 'push' && github.ref == 'refs/heads/auto' && github.repository == 'rust-lang-ci/rust'
307 #############################
308 # Linux/Docker builders #
309 #############################
312 <<: *job-aarch64-linux
320 - name: dist-aarch64-linux
326 - name: dist-arm-linux
329 - name: dist-armhf-linux
332 - name: dist-armv7-linux
335 - name: dist-i586-gnu-i586-i686-musl
338 - name: dist-i686-linux
341 - name: dist-mips-linux
344 - name: dist-mips64-linux
347 - name: dist-mips64el-linux
350 - name: dist-mipsel-linux
353 - name: dist-powerpc-linux
356 - name: dist-powerpc64-linux
359 - name: dist-powerpc64le-linux
362 - name: dist-riscv64-linux
365 - name: dist-s390x-linux
368 - name: dist-various-1
371 - name: dist-various-2
374 - name: dist-x86_64-freebsd
377 - name: dist-x86_64-illumos
381 name: dist-x86_64-linux
384 - name: dist-x86_64-linux-alt
386 IMAGE: dist-x86_64-linux
389 - name: dist-x86_64-musl
392 - name: dist-x86_64-netbsd
398 - name: i686-gnu-nopt
413 # This job ensures commits landing on nightly still pass the full
414 # test suite on the stable channel. There are some UI tests that
415 # depend on the channel being built (for example if they include the
416 # channel name on the output), and this builder prevents landing
417 # changes that would result in broken builds after a promotion.
418 - name: x86_64-gnu-stable
421 RUST_CI_OVERRIDE_RELEASE_CHANNEL: stable
422 # Only run this job on the nightly channel. Running this on beta
423 # could cause failures when `dev: 1` in `stage0.txt`, and running
424 # this on stable is useless.
425 CI_ONLY_WHEN_CHANNEL: nightly
428 - name: x86_64-gnu-aux
431 - name: x86_64-gnu-debug
434 - name: x86_64-gnu-distcheck
437 - name: x86_64-gnu-llvm-12
442 - name: x86_64-gnu-nopt
445 - name: x86_64-gnu-tools
447 DEPLOY_TOOLSTATES_JSON: toolstates-linux.json
454 - name: dist-x86_64-apple
456 SCRIPT: ./x.py dist --host=x86_64-apple-darwin --target=x86_64-apple-darwin
457 RUST_CONFIGURE_ARGS: --enable-full-tools --enable-sanitizers --enable-profiler --set rust.jemalloc --set llvm.ninja=false
458 RUSTC_RETRY_LINKER_ON_SEGFAULT: 1
459 MACOSX_DEPLOYMENT_TARGET: 10.7
460 NO_LLVM_ASSERTIONS: 1
461 NO_DEBUG_ASSERTIONS: 1
462 NO_OVERFLOW_CHECKS: 1
463 DIST_REQUIRE_ALL_TOOLS: 1
466 - name: dist-apple-various
468 SCRIPT: ./x.py dist --host='' --target=aarch64-apple-ios,x86_64-apple-ios,aarch64-apple-ios-sim
469 RUST_CONFIGURE_ARGS: --enable-sanitizers --enable-profiler --set rust.jemalloc --set llvm.ninja=false
470 RUSTC_RETRY_LINKER_ON_SEGFAULT: 1
471 MACOSX_DEPLOYMENT_TARGET: 10.7
472 NO_LLVM_ASSERTIONS: 1
473 NO_DEBUG_ASSERTIONS: 1
474 NO_OVERFLOW_CHECKS: 1
477 - name: dist-x86_64-apple-alt
480 RUST_CONFIGURE_ARGS: --enable-extended --enable-profiler --set rust.jemalloc --set llvm.ninja=false
481 RUSTC_RETRY_LINKER_ON_SEGFAULT: 1
482 MACOSX_DEPLOYMENT_TARGET: 10.7
483 NO_LLVM_ASSERTIONS: 1
484 NO_DEBUG_ASSERTIONS: 1
485 NO_OVERFLOW_CHECKS: 1
488 - name: x86_64-apple-1
489 env: &env-x86_64-apple-tests
490 SCRIPT: ./x.py --stage 2 test --exclude src/test/ui --exclude src/test/rustdoc --exclude src/test/run-make-fulldeps
491 RUST_CONFIGURE_ARGS: --build=x86_64-apple-darwin --enable-sanitizers --enable-profiler --set rust.jemalloc --set llvm.ninja=false
492 RUSTC_RETRY_LINKER_ON_SEGFAULT: 1
493 MACOSX_DEPLOYMENT_TARGET: 10.8
494 MACOSX_STD_DEPLOYMENT_TARGET: 10.7
495 NO_LLVM_ASSERTIONS: 1
496 NO_DEBUG_ASSERTIONS: 1
497 NO_OVERFLOW_CHECKS: 1
500 - name: x86_64-apple-2
502 SCRIPT: ./x.py --stage 2 test src/test/ui src/test/rustdoc src/test/run-make-fulldeps
503 <<: *env-x86_64-apple-tests
506 # This target only needs to support 11.0 and up as nothing else supports the hardware
507 - name: dist-aarch64-apple
509 SCRIPT: ./x.py dist --stage 2
510 RUST_CONFIGURE_ARGS: >-
511 --build=x86_64-apple-darwin
512 --host=aarch64-apple-darwin
513 --target=aarch64-apple-darwin
519 --set llvm.ninja=false
520 RUSTC_RETRY_LINKER_ON_SEGFAULT: 1
522 MACOSX_DEPLOYMENT_TARGET: 11.0
523 MACOSX_STD_DEPLOYMENT_TARGET: 11.0
524 NO_LLVM_ASSERTIONS: 1
525 NO_DEBUG_ASSERTIONS: 1
526 NO_OVERFLOW_CHECKS: 1
527 DIST_REQUIRE_ALL_TOOLS: 1
528 # Corresponds to 16K page size
530 # Shouldn't be needed if jemalloc-sys is updated to
531 # handle this platform like iOS or if we build on
532 # aarch64-apple-darwin itself.
534 # https://github.com/gnzlbg/jemallocator/blob/c27a859e98e3cb790dc269773d9da71a1e918458/jemalloc-sys/build.rs#L237
535 JEMALLOC_SYS_WITH_LG_PAGE: 14
538 ######################
540 ######################
542 - name: x86_64-msvc-1
544 RUST_CONFIGURE_ARGS: --build=x86_64-pc-windows-msvc --enable-profiler
545 SCRIPT: make ci-subset-1
548 - name: x86_64-msvc-2
550 RUST_CONFIGURE_ARGS: --build=x86_64-pc-windows-msvc --enable-profiler
551 SCRIPT: make ci-subset-2
556 RUST_CONFIGURE_ARGS: --build=i686-pc-windows-msvc
557 SCRIPT: make ci-subset-1
562 RUST_CONFIGURE_ARGS: --build=i686-pc-windows-msvc
563 SCRIPT: make ci-subset-2
566 - name: x86_64-msvc-cargo
568 SCRIPT: python x.py --stage 2 test src/tools/cargotest src/tools/cargo
569 RUST_CONFIGURE_ARGS: --build=x86_64-pc-windows-msvc --enable-lld
572 - name: x86_64-msvc-tools
574 SCRIPT: src/ci/docker/host-x86_64/x86_64-gnu-tools/checktools.sh x.py /tmp/toolstate/toolstates.json windows
575 RUST_CONFIGURE_ARGS: --build=x86_64-pc-windows-msvc --save-toolstates=/tmp/toolstate/toolstates.json
576 DEPLOY_TOOLSTATES_JSON: toolstates-windows.json
579 # 32/64-bit MinGW builds.
581 # We are using MinGW with POSIX threads since LLVM requires
582 # C++'s std::thread which is disabled in libstdc++ with win32 threads.
583 # FIXME: Libc++ doesn't have this limitation so we can avoid
584 # winpthreads if we switch to it.
586 # Instead of relying on the MinGW version installed on CI we download
587 # and install one ourselves so we won't be surprised by changes to CI's
590 # Finally, note that the downloads below are all in the `rust-lang-ci` S3
591 # bucket, but they clearly didn't originate there! The downloads originally
592 # came from the mingw-w64 SourceForge download site. Unfortunately
593 # SourceForge is notoriously flaky, so we mirror it on our own infrastructure.
597 RUST_CONFIGURE_ARGS: --build=i686-pc-windows-gnu
598 SCRIPT: make ci-mingw-subset-1
604 RUST_CONFIGURE_ARGS: --build=i686-pc-windows-gnu
605 SCRIPT: make ci-mingw-subset-2
609 - name: x86_64-mingw-1
611 SCRIPT: make ci-mingw-subset-1
612 RUST_CONFIGURE_ARGS: --build=x86_64-pc-windows-gnu --enable-profiler
616 - name: x86_64-mingw-2
618 SCRIPT: make ci-mingw-subset-2
619 RUST_CONFIGURE_ARGS: --build=x86_64-pc-windows-gnu --enable-profiler
623 - name: dist-x86_64-msvc
625 RUST_CONFIGURE_ARGS: >-
626 --build=x86_64-pc-windows-msvc
627 --host=x86_64-pc-windows-msvc
628 --target=x86_64-pc-windows-msvc
631 SCRIPT: PGO_HOST=x86_64-pc-windows-msvc src/ci/pgo.sh python x.py dist
632 DIST_REQUIRE_ALL_TOOLS: 1
635 - name: dist-i686-msvc
637 RUST_CONFIGURE_ARGS: >-
638 --build=i686-pc-windows-msvc
639 --host=i686-pc-windows-msvc
640 --target=i686-pc-windows-msvc,i586-pc-windows-msvc
643 SCRIPT: python x.py dist
644 DIST_REQUIRE_ALL_TOOLS: 1
647 - name: dist-aarch64-msvc
649 RUST_CONFIGURE_ARGS: >-
650 --build=x86_64-pc-windows-msvc
651 --host=aarch64-pc-windows-msvc
654 SCRIPT: python x.py dist
655 # RLS does not build for aarch64-pc-windows-msvc. See rust-lang/rls#1693
656 DIST_REQUIRE_ALL_TOOLS: 0
657 # Hack around this SDK version, because it doesn't work with clang.
658 # See https://github.com/rust-lang/rust/issues/88796
659 WINDOWS_SDK_20348_HACK: 1
662 - name: dist-i686-mingw
664 RUST_CONFIGURE_ARGS: --build=i686-pc-windows-gnu --enable-full-tools --enable-profiler
665 SCRIPT: python x.py dist
667 DIST_REQUIRE_ALL_TOOLS: 1
670 - name: dist-x86_64-mingw
672 SCRIPT: python x.py dist
673 RUST_CONFIGURE_ARGS: --build=x86_64-pc-windows-gnu --enable-full-tools --enable-profiler
675 DIST_REQUIRE_ALL_TOOLS: 1
678 - name: dist-x86_64-msvc-alt
680 RUST_CONFIGURE_ARGS: --build=x86_64-pc-windows-msvc --enable-extended --enable-profiler
681 SCRIPT: python x.py dist
688 <<: [*shared-ci-variables, *prod-variables]
689 if: github.event_name == 'push' && (github.ref == 'refs/heads/try' || github.ref == 'refs/heads/try-perf') && github.repository == 'rust-lang-ci/rust'
694 name: dist-x86_64-linux
699 runs-on: ubuntu-latest
701 <<: [*prod-variables]
702 if: github.event_name == 'push' && github.ref == 'refs/heads/master' && github.repository == 'rust-lang-ci/rust'
704 - name: checkout the source code
705 uses: actions/checkout@v3
709 - name: publish toolstate
710 run: src/ci/publish_toolstate.sh
713 TOOLSTATE_REPO_ACCESS_TOKEN: ${{ secrets.TOOLSTATE_REPO_ACCESS_TOKEN }}
716 # These jobs don't actually test anything, but they're used to tell bors the
717 # build completed, as there is no practical way to detect when a workflow is
718 # successful listening to webhooks only.
721 if: "success() && github.event_name == 'push' && (github.ref == 'refs/heads/try' || github.ref == 'refs/heads/try-perf') && github.repository == 'rust-lang-ci/rust'"
722 <<: *base-success-job
725 if: "!success() && github.event_name == 'push' && (github.ref == 'refs/heads/try' || github.ref == 'refs/heads/try-perf') && github.repository == 'rust-lang-ci/rust'"
726 <<: *base-failure-job
729 if: "success() && github.event_name == 'push' && github.ref == 'refs/heads/auto' && github.repository == 'rust-lang-ci/rust'"
730 <<: *base-success-job
733 if: "!success() && github.event_name == 'push' && github.ref == 'refs/heads/auto' && github.repository == 'rust-lang-ci/rust'"
734 <<: *base-failure-job