# Please make sure that the `needs` field for the `conclusion` job # are updated when adding new jobs! name: CI on: pull_request: merge_group: concurrency: group: ${{ github.workflow }}-${{ github.event.pull_request.number || github.ref }} cancel-in-progress: true env: CARGO_INCREMENTAL: 0 CARGO_NET_RETRY: 10 CI: 1 RUST_BACKTRACE: short RUSTUP_MAX_RETRIES: 10 jobs: changes: runs-on: ubuntu-latest permissions: pull-requests: read outputs: typescript: ${{ steps.filter.outputs.typescript }} steps: - uses: actions/checkout@v4 - uses: dorny/paths-filter@1441771bbfdd59dcd748680ee64ebd8faab1a242 id: filter with: filters: | typescript: - 'editors/code/**' proc-macro-srv: if: github.repository == 'rust-lang/rust-analyzer' name: proc-macro-srv runs-on: ubuntu-latest env: RUSTFLAGS: "-D warnings" steps: - name: Checkout repository uses: actions/checkout@v4 with: ref: ${{ github.event.pull_request.head.sha }} - name: Install rustup-toolchain-install-master run: cargo install rustup-toolchain-install-master@1.6.0 # Install a pinned rustc commit to avoid surprises - name: Install Rust toolchain run: | RUSTC_VERSION=`cat rust-version` rustup-toolchain-install-master ${RUSTC_VERSION} -c rust-src -c rustfmt rustup default ${RUSTC_VERSION} # Emulate a nightly toolchain, because the toolchain installed above does not have "nightly" # in its version string. - name: Emulate a nightly toolchain run: echo "RUSTC_BOOTSTRAP=1" >> $GITHUB_ENV # https://github.com/actions-rust-lang/setup-rust-toolchain/blob/main/rust.json - name: Install Rust Problem Matcher run: echo "::add-matcher::.github/rust.json" - name: Test run: cargo test --features sysroot-abi -p proc-macro-srv -p proc-macro-srv-cli -p proc-macro-api -- --quiet - name: Check salsa dependency run: "! (cargo tree -p proc-macro-srv-cli | grep -q salsa)" rust: if: github.repository == 'rust-lang/rust-analyzer' name: Rust runs-on: ${{ matrix.os }} env: RUSTFLAGS: "-Dwarnings" CC: deny_c strategy: matrix: os: [ubuntu-latest, windows-latest, macos-latest] steps: - name: Checkout repository uses: actions/checkout@v4 with: ref: ${{ github.event.pull_request.head.sha }} - name: Install Rust toolchain run: | rustup update --no-self-update stable rustup default stable rustup component add --toolchain stable rust-src clippy # We always use a nightly rustfmt, regardless of channel, because we need # --file-lines. rustup toolchain install nightly --profile minimal --component rustfmt # 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" # - name: Cache Dependencies # uses: Swatinem/rust-cache@9d47c6ad4b02e050fd481d890b2ea34778fd09d6 # with: # workspaces: | # . -> target # ./crates/proc-macro-srv/proc-macro-test/imp -> target - name: Install nextest uses: taiki-e/install-action@nextest - name: Codegen checks (rust-analyzer) if: matrix.os == 'ubuntu-latest' run: cargo codegen --check - name: Compile tests run: cargo test --no-run - name: Run tests run: cargo nextest run --no-fail-fast --hide-progress-bar --status-level fail - name: Cancel parallel jobs if: failure() run: | # https://docs.github.com/en/rest/actions/workflow-runs?apiVersion=2022-11-28#cancel-a-workflow-run curl -L \ -X POST \ -H "Accept: application/vnd.github.v3+json" \ -H "Authorization: Bearer ${{ secrets.GITHUB_TOKEN }}" \ -H "X-GitHub-Api-Version: 2022-11-28" \ https://api.github.com/repos/${{ github.repository }}/actions/runs/${{ github.run_id }}/cancel - name: Run Clippy if: matrix.os == 'macos-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 analysis-stats: if: github.repository == 'rust-lang/rust-analyzer' runs-on: ubuntu-latest env: RUSTC_BOOTSTRAP: 1 steps: - name: Checkout repository uses: actions/checkout@v4 - name: Install Rust toolchain run: | rustup update --no-self-update stable rustup default stable rustup component add rustfmt # - name: Cache Dependencies # uses: Swatinem/rust-cache@9d47c6ad4b02e050fd481d890b2ea34778fd09d6 - name: Bump opt-level run: sed -i '/\[profile.dev]/a opt-level=1' Cargo.toml - run: cargo build -p rust-analyzer - name: ./rust-analyzer run: ./target/debug/rust-analyzer analysis-stats . -q - name: sysroot/lib/rustlib/src/rust/library/ run: ./target/debug/rust-analyzer analysis-stats --with-deps --no-sysroot --no-test $(rustc --print sysroot)/lib/rustlib/src/rust/library/ -q rustfmt: if: github.repository == 'rust-lang/rust-analyzer' runs-on: ubuntu-latest steps: - name: Checkout repository uses: actions/checkout@v4 - name: Install Rust toolchain run: | rustup update --no-self-update stable rustup default stable rustup component add rustfmt - run: cargo fmt -- --check miri: if: github.repository == 'rust-lang/rust-analyzer' runs-on: ubuntu-latest steps: - name: Checkout repository uses: actions/checkout@v4 - name: Install Rust toolchain run: | rustup update --no-self-update nightly rustup default nightly rustup component add miri # - name: Cache Dependencies # uses: Swatinem/rust-cache@9d47c6ad4b02e050fd481d890b2ea34778fd09d6 - run: cargo miri test -p intern # Weird targets to catch non-portable code rust-cross: if: github.repository == 'rust-lang/rust-analyzer' name: Rust Cross runs-on: ubuntu-latest strategy: matrix: target: [powerpc-unknown-linux-gnu, x86_64-unknown-linux-musl, wasm32-unknown-unknown] include: # The rust-analyzer binary is not expected to compile on WASM, but the IDE # crate should - target: wasm32-unknown-unknown ide-only: true env: RUSTFLAGS: "-Dwarnings" steps: - name: Checkout repository uses: actions/checkout@v4 - name: Install Rust toolchain run: | rustup update --no-self-update stable rustup target add ${{ matrix.target }} # - name: Cache Dependencies # uses: Swatinem/rust-cache@9d47c6ad4b02e050fd481d890b2ea34778fd09d6 - run: cargo check --target=${{ matrix.target }} --all-targets -p ide if: ${{ matrix.ide-only }} - run: cargo check --target=${{ matrix.target }} --all-targets if: ${{ !matrix.ide-only }} typescript: needs: changes if: github.repository == 'rust-lang/rust-analyzer' && needs.changes.outputs.typescript == 'true' name: TypeScript strategy: fail-fast: false matrix: os: [ubuntu-latest, windows-latest] runs-on: ${{ matrix.os }} steps: - name: Checkout repository uses: actions/checkout@v4 - name: Install Nodejs uses: actions/setup-node@v4 with: node-version: 22 - name: Install xvfb if: matrix.os == 'ubuntu-latest' run: sudo apt-get install -y xvfb - run: npm ci working-directory: ./editors/code # - 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 # You may fix the code automatically by running `npm run lint:fix` if this steps fails. - run: npm run lint working-directory: ./editors/code # To fix this steps, please run `npm run format`. - run: npm run format:check working-directory: ./editors/code - name: Run VS Code tests (Linux) if: matrix.os == 'ubuntu-latest' env: VSCODE_CLI: 1 run: xvfb-run npm test working-directory: ./editors/code - name: Run VS Code tests (Windows) if: matrix.os == 'windows-latest' env: VSCODE_CLI: 1 run: npm test working-directory: ./editors/code - run: npm run package --scripts-prepend-node-path working-directory: ./editors/code typo-check: name: Typo Check runs-on: ubuntu-latest timeout-minutes: 10 env: FORCE_COLOR: 1 TYPOS_VERSION: v1.28.3 steps: - 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 - name: Checkout repository uses: actions/checkout@v4 with: ref: ${{ github.event.pull_request.head.sha }} - name: check for typos run: typos conclusion: needs: [rust, rust-cross, typescript, typo-check, proc-macro-srv, miri, rustfmt, analysis-stats] # 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() }} runs-on: ubuntu-latest steps: # 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 (or have been skipped). jq --exit-status 'all(.result == "success" or .result == "skipped")' <<< '${{ toJson(needs) }}'