wip #3
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
############################################################# | |
# WARNING: automatically generated file, DO NOT CHANGE! # | |
############################################################# | |
# This file was automatically generated by the expand-yaml-anchors tool. The | |
# source file that generated this one is: | |
# | |
# src/ci/github-actions/ci.yml | |
# | |
# Once you make changes to that file you need to run: | |
# | |
# ./x.py run src/tools/expand-yaml-anchors/ | |
# | |
# The CI build will fail if the tool is not run after changes to this file. | |
--- | |
name: CI | |
"on": | |
push: | |
branches: | |
- m1-mac | |
- auto | |
- try | |
- try-perf | |
- automation/bors/try | |
- master | |
pull_request: | |
branches: | |
- "**" | |
permissions: | |
contents: read | |
packages: write | |
defaults: | |
run: | |
shell: bash | |
concurrency: | |
group: "${{ github.workflow }}-${{ ((github.ref == 'refs/heads/try' || github.ref == 'refs/heads/try-perf') && github.sha) || github.ref }}" | |
cancel-in-progress: true | |
jobs: | |
auto: | |
name: "auto - ${{ matrix.name }}" | |
env: | |
CI_JOB_NAME: "${{ matrix.name }}" | |
CARGO_REGISTRIES_CRATES_IO_PROTOCOL: sparse | |
HEAD_SHA: "${{ github.event.pull_request.head.sha || github.sha }}" | |
DOCKER_TOKEN: "${{ secrets.GITHUB_TOKEN }}" | |
SCCACHE_BUCKET: rust-lang-ci-sccache2 | |
DEPLOY_BUCKET: rust-lang-ci2 | |
TOOLSTATE_REPO: "https://github.com/rust-lang-nursery/rust-toolstate" | |
TOOLSTATE_ISSUES_API_URL: "https://api.github.com/repos/rust-lang/rust/issues" | |
TOOLSTATE_PUBLISH: 1 | |
CACHES_AWS_ACCESS_KEY_ID: AKIA46X5W6CZI5DHEBFL | |
ARTIFACTS_AWS_ACCESS_KEY_ID: AKIA46X5W6CZN24CBO55 | |
AWS_REGION: us-west-1 | |
CACHE_DOMAIN: ci-caches.rust-lang.org | |
if: "github.event_name == 'push'" | |
strategy: | |
matrix: | |
include: | |
- name: aarch64-apple-1 | |
env: | |
SCRIPT: "./x.py --stage 2 test --skip tests/ui --skip tests/rustdoc --skip tests/run-make-fulldeps" | |
RUST_CONFIGURE_ARGS: "--build=aarch64-apple-darwin --enable-sanitizers --enable-profiler --set rust.jemalloc --set llvm.ninja=false" | |
RUSTC_RETRY_LINKER_ON_SEGFAULT: 1 | |
MACOSX_DEPLOYMENT_TARGET: 10.12 | |
MACOSX_STD_DEPLOYMENT_TARGET: 10.12 | |
NO_LLVM_ASSERTIONS: 1 | |
NO_DEBUG_ASSERTIONS: 1 | |
NO_OVERFLOW_CHECKS: 1 | |
os: macos-14 | |
- name: aarch64-apple-2 | |
env: | |
SCRIPT: "./x.py --stage 2 test tests/ui tests/rustdoc tests/run-make-fulldeps" | |
RUST_CONFIGURE_ARGS: "--build=aarch64-apple-darwin --enable-sanitizers --enable-profiler --set rust.jemalloc --set llvm.ninja=false" | |
RUSTC_RETRY_LINKER_ON_SEGFAULT: 1 | |
MACOSX_DEPLOYMENT_TARGET: 10.12 | |
MACOSX_STD_DEPLOYMENT_TARGET: 10.12 | |
NO_LLVM_ASSERTIONS: 1 | |
NO_DEBUG_ASSERTIONS: 1 | |
NO_OVERFLOW_CHECKS: 1 | |
os: macos-14 | |
timeout-minutes: 600 | |
runs-on: "${{ matrix.os }}" | |
steps: | |
- name: disable git crlf conversion | |
run: git config --global core.autocrlf false | |
- name: checkout the source code | |
uses: actions/checkout@v4 | |
with: | |
fetch-depth: 2 | |
- name: configure the PR in which the error message will be posted | |
run: "echo \"[CI_PR_NUMBER=$num]\"" | |
env: | |
num: "${{ github.event.number }}" | |
if: "success() && !env.SKIP_JOB && github.event_name == 'pull_request'" | |
- name: add extra environment variables | |
run: src/ci/scripts/setup-environment.sh | |
env: | |
EXTRA_VARIABLES: "${{ toJson(matrix.env) }}" | |
if: success() && !env.SKIP_JOB | |
- name: decide whether to skip this job | |
run: src/ci/scripts/should-skip-this.sh | |
if: success() && !env.SKIP_JOB | |
- name: ensure the channel matches the target branch | |
run: src/ci/scripts/verify-channel.sh | |
if: success() && !env.SKIP_JOB | |
- name: collect CPU statistics | |
run: src/ci/scripts/collect-cpu-stats.sh | |
if: success() && !env.SKIP_JOB | |
- name: show the current environment | |
run: src/ci/scripts/dump-environment.sh | |
if: success() && !env.SKIP_JOB | |
- name: install awscli | |
run: src/ci/scripts/install-awscli.sh | |
if: success() && !env.SKIP_JOB | |
- name: install sccache | |
run: src/ci/scripts/install-sccache.sh | |
if: success() && !env.SKIP_JOB | |
- name: select Xcode | |
run: src/ci/scripts/select-xcode.sh | |
if: success() && !env.SKIP_JOB | |
- name: install clang | |
run: src/ci/scripts/install-clang.sh | |
if: success() && !env.SKIP_JOB | |
- name: install tidy | |
run: src/ci/scripts/install-tidy.sh | |
if: success() && !env.SKIP_JOB | |
- name: install WIX | |
run: src/ci/scripts/install-wix.sh | |
if: success() && !env.SKIP_JOB | |
- name: disable git crlf conversion | |
run: src/ci/scripts/disable-git-crlf-conversion.sh | |
if: success() && !env.SKIP_JOB | |
- name: checkout submodules | |
run: src/ci/scripts/checkout-submodules.sh | |
if: success() && !env.SKIP_JOB | |
- name: install MSYS2 | |
run: src/ci/scripts/install-msys2.sh | |
if: success() && !env.SKIP_JOB | |
- name: install MinGW | |
run: src/ci/scripts/install-mingw.sh | |
if: success() && !env.SKIP_JOB | |
- name: install ninja | |
run: src/ci/scripts/install-ninja.sh | |
if: success() && !env.SKIP_JOB | |
- name: enable ipv6 on Docker | |
run: src/ci/scripts/enable-docker-ipv6.sh | |
if: success() && !env.SKIP_JOB | |
- name: disable git crlf conversion | |
run: src/ci/scripts/disable-git-crlf-conversion.sh | |
if: success() && !env.SKIP_JOB | |
- name: ensure line endings are correct | |
run: src/ci/scripts/verify-line-endings.sh | |
if: success() && !env.SKIP_JOB | |
- name: ensure backported commits are in upstream branches | |
run: src/ci/scripts/verify-backported-commits.sh | |
if: success() && !env.SKIP_JOB | |
- name: ensure the stable version number is correct | |
run: src/ci/scripts/verify-stable-version-number.sh | |
if: success() && !env.SKIP_JOB | |
- name: run the build | |
run: src/ci/scripts/run-build-from-ci.sh | |
env: | |
AWS_ACCESS_KEY_ID: "${{ env.CACHES_AWS_ACCESS_KEY_ID }}" | |
AWS_SECRET_ACCESS_KEY: "${{ secrets[format('AWS_SECRET_ACCESS_KEY_{0}', env.CACHES_AWS_ACCESS_KEY_ID)] }}" | |
TOOLSTATE_REPO_ACCESS_TOKEN: "${{ secrets.TOOLSTATE_REPO_ACCESS_TOKEN }}" | |
if: success() && !env.SKIP_JOB | |
- name: create github artifacts | |
run: src/ci/scripts/create-doc-artifacts.sh | |
if: success() && !env.SKIP_JOB | |
- name: upload artifacts to github | |
uses: actions/upload-artifact@v3 | |
with: | |
name: "${{ env.DOC_ARTIFACT_NAME }}" | |
path: obj/artifacts/doc | |
if-no-files-found: ignore | |
retention-days: 5 | |
if: success() && !env.SKIP_JOB | |
- name: upload artifacts to S3 | |
run: src/ci/scripts/upload-artifacts.sh | |
env: | |
AWS_ACCESS_KEY_ID: "${{ env.ARTIFACTS_AWS_ACCESS_KEY_ID }}" | |
AWS_SECRET_ACCESS_KEY: "${{ secrets[format('AWS_SECRET_ACCESS_KEY_{0}', env.ARTIFACTS_AWS_ACCESS_KEY_ID)] }}" | |
if: "success() && !env.SKIP_JOB && (github.event_name == 'push' || env.DEPLOY == '1' || env.DEPLOY_ALT == '1')" |