This GitHub Action installs a Rust toolchain using rustup. It further integrates into the ecosystem. Caching for Rust tools and build artifacts is enabled. Environment variables are set to optimize the cache hits. Problem Matchers are provided for build messages (cargo, clippy) and formatting (rustfmt).
The action is heavily inspired by dtolnay's https://github.com/dtolnay/rust-toolchain and extends it with further features.
name: "Test Suite"
on:
  push:
  pull_request:
jobs:
  test:
    name: cargo test
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v5
      - uses: actions-rust-lang/setup-rust-toolchain@v1
      - run: cargo test --all-features
  # Check formatting with rustfmt
  formatting:
    name: cargo fmt
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v5
      # Ensure rustfmt is installed and setup problem matcher
      - uses: actions-rust-lang/setup-rust-toolchain@v1
        with:
          components: rustfmt
      - name: Rustfmt Check
        uses: actions-rust-lang/rustfmt@v1All inputs are optional.
If a toolchain file (i.e., rust-toolchain or rust-toolchain.toml) is found in the root of the repository and no toolchain value is provided, all items specified in the toolchain file will be installed.
If a toolchain value is provided, the toolchain file will be ignored.
If no toolchain value or toolchain file is present, it will default to stable.
First, all items specified in the toolchain file are installed.
Afterward, the components and target specified via inputs are installed in addition to the items from the toolchain file.
| Name | Description | Default | 
|---|---|---|
| toolchain | Comma-separated list of Rustup toolchain specifier e.g. stable,nightly,1.42.0. The last version is the default. | stable | 
| target | Additional target support to install e.g. wasm32-unknown-unknown | |
| components | Comma-separated string of additional components to install e.g. clippy, rustfmt | |
| cache | Automatically configure Rust cache (using Swatinem/rust-cache) | true | 
| cache-directories | Propagates the value to Swatinem/rust-cache | |
| cache-workspaces | Propagates the value to Swatinem/rust-cache. Influenced by the value ofrust-src-dir. | |
| cache-on-failure | Propagates the value to Swatinem/rust-cache | true | 
| cache-key | Propagates the value to Swatinem/rust-cacheaskey | |
| cache-shared-key | Propagates the value to Swatinem/rust-cacheasshared-key | |
| cache-bin | Propagates the value to Swatinem/rust-cacheascache-bin | true | 
| cache-provider | Propagates the value to Swatinem/rust-cacheascache-provider | 'github' | 
| cache-all-crates | Propagates the value to Swatinem/rust-cacheascache-all-crates | false | 
| cache-workspace-crates | Propagates the value to Swatinem/rust-cacheascache-workspace-crates | false | 
| matcher | Enable problem matcher to surface build messages and formatting issues | true | 
| rustflags | Set the value of RUSTFLAGS(set to empty string to avoid overwriting existing flags) | "-D warnings" | 
| override | Setup the last installed toolchain as the default via rustup override | true | 
| rust-src-dir | Path from root directory to directory with the Rust source directory (if its not in the root of the repository). Sets a default value for cache-workspacesthat enables caching. | 
By default, this action sets the RUSTFLAGS environment variable to -D warnings.
However, rustflags sources are mutually exclusive, so setting this environment variable omits any configuration through target.*.rustflags or build.rustflags.
- If RUSTFLAGSis already set, no modifications of the variable are made and the original value remains.
- If RUSTFLAGSis unset and therustflagsinput is empty (i.e., the empty string), then it will remain unset. Use this, if you want to prevent the value from being set because you make use oftarget.*.rustflagsorbuild.rustflags.
- Otherwise, the environment variable RUSTFLAGSis set to the content ofrustflags.
To prevent this from happening, set the rustflags input to an empty string, which will
prevent the action from setting RUSTFLAGS at all, keeping any existing preferences.
You can read more rustflags, and their load order, in the Cargo reference.
| Name | Description | 
|---|---|
| rustc-version | Version as reported by rustc --version | 
| cargo-version | Version as reported by cargo --version | 
| rustup-version | Version as reported by rustup --version | 
| cachekey | A short hash of the installed rustc version | 
The action works best on the GitHub-hosted runners, but can work on self-hosted ones too, provided the necessary dependencies are available. PRs to add support for more environments are welcome.
- bash 5
- brew (macOS only)
- rustup or curl
- using other node actions
The scripts and documentation in this project are released under the MIT License.