rust-analyzer/.github/workflows/ci.yaml

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

258 lines
8.7 KiB
YAML
Raw Normal View History

2024-10-22 12:04:24 +00:00
# Please make sure that the `needs` field for the `conclusion` job
2022-04-13 14:13:36 +00:00
# are updated when adding new jobs!
2019-11-18 08:13:31 +00:00
name: CI
on:
pull_request:
2024-10-22 12:04:24 +00:00
merge_group:
2019-11-16 22:26:54 +00:00
concurrency:
group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }}
cancel-in-progress: true
2020-03-26 09:21:00 +00:00
env:
CARGO_INCREMENTAL: 0
CARGO_NET_RETRY: 10
2020-04-06 15:01:46 +00:00
CI: 1
2020-03-30 08:49:11 +00:00
RUST_BACKTRACE: short
2024-07-25 05:27:15 +00:00
RUSTFLAGS: "-D warnings -D elided_lifetimes_in_paths -D explicit_outlives_requirements -D unsafe_op_in_unsafe_fn -D unused_extern_crates -D unused_lifetimes -D unreachable_pub"
2020-03-26 09:21:00 +00:00
RUSTUP_MAX_RETRIES: 10
2019-11-16 22:26:54 +00:00
jobs:
changes:
2020-07-14 09:01:18 +00:00
runs-on: ubuntu-latest
permissions:
2022-09-06 18:20:49 +00:00
pull-requests: read
outputs:
2022-10-18 06:12:49 +00:00
typescript: ${{ steps.filter.outputs.typescript }}
proc_macros: ${{ steps.filter.outputs.proc_macros }}
steps:
2024-02-16 12:23:10 +00:00
- uses: actions/checkout@v4
2024-02-07 17:24:35 +00:00
- uses: dorny/paths-filter@1441771bbfdd59dcd748680ee64ebd8faab1a242
id: filter
with:
filters: |
2020-02-26 19:05:27 +00:00
typescript:
2022-09-06 18:20:49 +00:00
- 'editors/code/**'
proc_macros:
- 'crates/proc-macro-api/**'
- 'crates/proc-macro-srv/**'
- 'crates/proc-macro-srv-cli/**'
2019-11-18 08:13:31 +00:00
rust:
needs: changes
2022-04-13 22:42:51 +00:00
if: github.repository == 'rust-lang/rust-analyzer'
2019-11-18 08:13:31 +00:00
name: Rust
2020-01-02 14:08:36 +00:00
runs-on: ${{ matrix.os }}
2020-04-05 13:45:57 +00:00
env:
2020-07-14 02:04:00 +00:00
CC: deny_c
RUST_CHANNEL: "${{ needs.changes.outputs.proc_macros == 'true' && 'nightly' || 'stable' }}"
USE_SYSROOT_ABI: "${{ needs.changes.outputs.proc_macros == 'true' && '--features sysroot-abi' || '' }}"
2020-03-04 16:01:38 +00:00
2020-01-02 14:08:36 +00:00
strategy:
2020-01-22 10:53:47 +00:00
fail-fast: false
2020-01-02 14:08:36 +00:00
matrix:
2020-08-18 07:38:32 +00:00
os: [ubuntu-latest, windows-latest, macos-latest]
2020-03-04 16:01:38 +00:00
steps:
2022-09-06 18:20:49 +00:00
- name: Checkout repository
2024-02-16 12:23:10 +00:00
uses: actions/checkout@v4
2022-09-06 18:20:49 +00:00
with:
ref: ${{ github.event.pull_request.head.sha }}
2020-03-04 16:01:38 +00:00
2022-09-06 18:20:49 +00:00
- name: Install Rust toolchain
run: |
rustup update --no-self-update ${{ env.RUST_CHANNEL }}
rustup default ${{ env.RUST_CHANNEL }}
2024-05-15 07:49:42 +00:00
rustup component add --toolchain ${{ env.RUST_CHANNEL }} rustfmt rust-src
2024-02-14 10:34:43 +00:00
# https://github.com/actions-rust-lang/setup-rust-toolchain/blob/main/rust.json
- name: Install Rust Problem Matcher
if: matrix.os == 'ubuntu-latest'
run: echo "::add-matcher::.github/rust.json"
2022-09-06 18:20:49 +00:00
- name: Cache Dependencies
2024-05-15 07:50:34 +00:00
uses: Swatinem/rust-cache@9bdad043e88c75890e36ad3bbc8d27f0090dd609
with:
2022-09-06 18:20:49 +00:00
key: ${{ env.RUST_CHANNEL }}
2020-03-04 16:01:38 +00:00
2022-10-18 06:12:49 +00:00
- name: Bump opt-level
if: matrix.os == 'ubuntu-latest'
run: sed -i '/\[profile.dev]/a opt-level=1' Cargo.toml
- name: Codegen checks (rust-analyzer)
run: cargo codegen --check
2022-10-18 06:12:49 +00:00
- name: Compile (tests)
2022-09-06 18:20:49 +00:00
run: cargo test --no-run --locked ${{ env.USE_SYSROOT_ABI }}
2020-03-04 16:01:38 +00:00
2022-10-18 06:12:49 +00:00
# It's faster to `test` before `build` ¯\_(ツ)_/¯
- name: Compile (rust-analyzer)
if: matrix.os == 'ubuntu-latest'
run: cargo build --quiet ${{ env.USE_SYSROOT_ABI }}
2022-09-06 18:20:49 +00:00
- name: Test
if: matrix.os == 'ubuntu-latest' || matrix.os == 'windows-latest' || github.event_name == 'push'
2022-09-06 18:20:49 +00:00
run: cargo test ${{ env.USE_SYSROOT_ABI }} -- --nocapture --quiet
2020-03-04 16:01:38 +00:00
2023-08-22 06:26:04 +00:00
- name: Switch to stable toolchain
run: |
rustup update --no-self-update stable
2024-01-21 23:06:52 +00:00
rustup component add --toolchain stable rust-src clippy
2023-08-22 06:26:04 +00:00
rustup default stable
2022-10-18 06:12:49 +00:00
- name: Run analysis-stats on rust-analyzer
if: matrix.os == 'ubuntu-latest'
run: target/${{ matrix.target }}/debug/rust-analyzer analysis-stats .
- name: Run analysis-stats on the rust standard libraries
2022-10-18 06:12:49 +00:00
if: matrix.os == 'ubuntu-latest'
2023-08-28 07:22:33 +00:00
env:
RUSTC_BOOTSTRAP: 1
run: target/${{ matrix.target }}/debug/rust-analyzer analysis-stats --with-deps --no-sysroot --no-test $(rustc --print sysroot)/lib/rustlib/src/rust/library/
2022-10-18 06:12:49 +00:00
2024-01-21 23:06:52 +00:00
- name: clippy
2024-02-06 09:22:26 +00:00
if: matrix.os == 'windows-latest'
run: cargo clippy --all-targets -- -D clippy::disallowed_macros -D clippy::dbg_macro -D clippy::todo -D clippy::print_stdout -D clippy::print_stderr
2024-01-21 23:06:52 +00:00
2024-02-14 10:34:43 +00:00
- name: rustfmt
if: matrix.os == 'ubuntu-latest'
run: cargo fmt -- --check
2020-08-12 09:49:49 +00:00
# Weird targets to catch non-portable code
rust-cross:
2022-04-13 22:42:51 +00:00
if: github.repository == 'rust-lang/rust-analyzer'
2020-08-12 09:49:49 +00:00
name: Rust Cross
2020-07-14 09:01:18 +00:00
runs-on: ubuntu-latest
2020-08-12 09:49:49 +00:00
env:
targets: "powerpc-unknown-linux-gnu x86_64-unknown-linux-musl"
# The rust-analyzer binary is not expected to compile on WASM, but the IDE
# crate should
targets_ide: "wasm32-unknown-unknown"
2020-08-12 09:49:49 +00:00
2020-07-14 09:01:18 +00:00
steps:
2022-09-06 18:20:49 +00:00
- name: Checkout repository
2024-02-16 12:23:10 +00:00
uses: actions/checkout@v4
2022-09-06 18:20:49 +00:00
- name: Install Rust toolchain
run: |
rustup update --no-self-update stable
rustup target add ${{ env.targets }} ${{ env.targets_ide }}
- name: Cache Dependencies
2024-05-15 07:50:34 +00:00
uses: Swatinem/rust-cache@9bdad043e88c75890e36ad3bbc8d27f0090dd609
2022-09-06 18:20:49 +00:00
- name: Check
run: |
for target in ${{ env.targets }}; do
cargo check --target=$target --all-targets
done
for target in ${{ env.targets_ide }}; do
cargo check -p ide --target=$target --all-targets
done
2020-07-14 09:01:18 +00:00
2020-02-26 19:05:27 +00:00
typescript:
needs: changes
2022-04-13 22:42:51 +00:00
if: github.repository == 'rust-lang/rust-analyzer'
2019-11-18 08:13:31 +00:00
name: TypeScript
2020-05-23 13:39:30 +00:00
strategy:
fail-fast: false
matrix:
os: [ubuntu-latest, windows-latest]
2020-05-23 13:39:30 +00:00
runs-on: ${{ matrix.os }}
2020-07-14 09:01:18 +00:00
2019-11-16 22:26:54 +00:00
steps:
2022-09-06 18:20:49 +00:00
- name: Checkout repository
2024-02-16 12:23:10 +00:00
uses: actions/checkout@v4
2022-04-13 14:13:36 +00:00
if: needs.changes.outputs.typescript == 'true'
2022-09-06 18:20:49 +00:00
- name: Install Nodejs
uses: actions/setup-node@v4
2022-09-06 18:20:49 +00:00
with:
node-version: 18
2022-04-13 14:13:36 +00:00
if: needs.changes.outputs.typescript == 'true'
2022-09-06 18:20:49 +00:00
- name: Install xvfb
if: matrix.os == 'ubuntu-latest' && needs.changes.outputs.typescript == 'true'
run: sudo apt-get install -y xvfb
- run: npm ci
working-directory: ./editors/code
2022-04-13 14:13:36 +00:00
if: needs.changes.outputs.typescript == 'true'
2022-09-06 18:20:49 +00:00
# - run: npm audit || { sleep 10 && npm audit; } || { sleep 30 && npm audit; }
# if: runner.os == 'Linux'
# working-directory: ./editors/code
# If this steps fails, your code's type integrity might be wrong at some places at TypeScript level.
- run: npm run typecheck
working-directory: ./editors/code
if: needs.changes.outputs.typescript == 'true'
# You may fix the code automatically by running `npm run lint:fix` if this steps fails.
2022-09-06 18:20:49 +00:00
- run: npm run lint
working-directory: ./editors/code
2022-04-13 14:13:36 +00:00
if: needs.changes.outputs.typescript == 'true'
2022-09-06 18:20:49 +00:00
# To fix this steps, please run `npm run format`.
- run: npm run format:check
working-directory: ./editors/code
if: needs.changes.outputs.typescript == 'true'
2022-09-06 18:20:49 +00:00
- name: Run VS Code tests (Linux)
if: matrix.os == 'ubuntu-latest' && needs.changes.outputs.typescript == 'true'
env:
VSCODE_CLI: 1
run: xvfb-run npm test
working-directory: ./editors/code
- name: Run VS Code tests (Windows)
if: matrix.os == 'windows-latest' && needs.changes.outputs.typescript == 'true'
env:
VSCODE_CLI: 1
run: npm test
working-directory: ./editors/code
- run: npm run package --scripts-prepend-node-path
working-directory: ./editors/code
2022-04-13 14:13:36 +00:00
if: needs.changes.outputs.typescript == 'true'
2024-02-02 10:32:20 +00:00
typo-check:
name: Typo Check
2024-02-01 13:07:50 +00:00
runs-on: ubuntu-latest
timeout-minutes: 10
env:
FORCE_COLOR: 1
2024-12-13 09:45:44 +00:00
TYPOS_VERSION: v1.28.3
2024-02-01 13:07:50 +00:00
steps:
2024-02-02 10:32:20 +00:00
- name: download typos
run: curl -LsSf https://github.com/crate-ci/typos/releases/download/$TYPOS_VERSION/typos-$TYPOS_VERSION-x86_64-unknown-linux-musl.tar.gz | tar zxf - -C ${CARGO_HOME:-~/.cargo}/bin
2024-02-01 13:07:50 +00:00
- name: Checkout repository
uses: actions/checkout@v4
with:
ref: ${{ github.event.pull_request.head.sha }}
2024-02-02 10:32:20 +00:00
- name: check for typos
2024-02-01 13:07:50 +00:00
run: typos
2024-10-22 12:04:24 +00:00
conclusion:
2024-02-02 10:32:20 +00:00
needs: [rust, rust-cross, typescript, typo-check]
2024-10-22 12:04:24 +00:00
# We need to ensure this job does *not* get skipped if its dependencies fail,
# because a skipped job is considered a success by GitHub. So we have to
# overwrite `if:`. We use `!cancelled()` to ensure the job does still not get run
# when the workflow is canceled manually.
#
# ALL THE PREVIOUS JOBS NEED TO BE ADDED TO THE `needs` SECTION OF THIS JOB!
if: ${{ !cancelled() }}
2022-04-13 14:13:36 +00:00
runs-on: ubuntu-latest
steps:
2024-10-22 12:04:24 +00:00
# Manually check the status of all dependencies. `if: failure()` does not work.
- name: Conclusion
run: |
# Print the dependent jobs to see them in the CI log
jq -C <<< '${{ toJson(needs) }}'
# Check if all jobs that we depend on (in the needs array) were successful.
jq --exit-status 'all(.result == "success")' <<< '${{ toJson(needs) }}'