name: build
on: [push]
jobs:
check:
name: Rust project
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
- name: Install latest nightly
uses: actions-rs/toolchain@v1
with:
toolchain: nightly
override: true
components: rustfmt, clippy
- name: Run cargo check
uses: actions-rs/cargo@v1
with:
command: check
rust-toolchain-action
This action installs and configures Rust toolchains with support for additional targets, components, and profiles.
What is rust-toolchain-action?β
The rust-toolchain-action
allows you to install Rust toolchains in your CI/CD workflows using rustup
. It supports setting up custom toolchains, installing additional components, and configuring profiles to optimize the installation process.
How to Install a Specific Toolchainβ
To install a specific Rust toolchain (e.g., stable, nightly), use the toolchain
input:
with:
toolchain: stable
You can specify different versions, such as nightly-2021-09-10
or a stable version like 1.32.0
.
How to Add Additional Targetsβ
If you need to install additional targets (e.g., for cross-compilation), specify them using the target
input:
with:
toolchain: stable
target: x86_64-apple-darwin
How to Set a Toolchain as Defaultβ
To set the installed toolchain as the default globally, use the default
input:
with:
toolchain: stable
default: true
How to Set a Toolchain for the Current Directoryβ
To override the toolchain for the current directory, use the override
input:
with:
toolchain: nightly
override: true
How to Use Profilesβ
You can use rustup
profiles to speed up the installation by installing only the minimal components required. To use the minimal
profile, for example:
with:
profile: minimal
toolchain: nightly
This skips the installation of extra components like documentation, reducing installation time.
How to Install Additional Componentsβ
To install extra components like clippy
or rustfmt
, use the components
input:
with:
toolchain: stable
components: rustfmt, clippy
For nightly builds, this action will automatically find the most recent nightly version that includes the requested components.
How to Use a Toolchain Fileβ
If your repository includes a rust-toolchain
file, the action will automatically use it unless you specify a toolchain
input. If both are present, the input takes priority.
How to Retrieve Output Informationβ
The action provides several output variables that you can use in subsequent steps of your workflow:
rustc
: Rust compiler version (e.g.,1.40.0
)rustc_hash
: Rust compiler version hash (useful for caching)cargo
: Cargo versionrustup
: Rustup version
Hereβs an example of how to access these outputs:
steps:
- name: Install toolchain
id: rust_install
uses: actions-rs/toolchain@v1
with:
toolchain: stable
- run: echo "Rust version: ${{ steps.rust_install.outputs.rustc }}"