A GitHub Action to run ruff.
This action is commonly used as a pass/fail test to ensure your repository stays
clean, abiding the rules specified in your
configuration. Though it runs ruff
, the action can do anything ruff
can (ex,
fix).
- Usage
- Outputs
Input | Description | Default |
---|---|---|
version |
The version of Ruff to install. See Install specific versions | latest |
version-file |
The file to read the version from. See Install a version from a specified version file | None |
args |
The arguments to pass to the ruff command. See Configuring Ruff |
check |
src |
The directory or single files to run ruff on. |
github.workspace |
checksum |
The sha256 checksum of the downloaded executable. | None |
github-token |
The GitHub token to use for authentication. | GITHUB_TOKEN |
- uses: astral-sh/ruff-action@v3
- uses: astral-sh/ruff-action@v3
with:
src: "./src"
- uses: astral-sh/ruff-action@v3
with:
src: >-
path/to/file1.py
path/to/file2.py
This action adds ruff to the PATH, so you can use it in subsequent steps.
- uses: astral-sh/ruff-action@v3
- run: ruff check --fix
- run: ruff format
- uses: astral-sh/ruff-action@v3
with:
args: "format --check"
By default this action looks for a pyproject.toml file in the root of the repository to determine
the ruff version to install. If no pyproject.toml file is found, or no ruff version is defined in
either dependencies
or dependency-groups.dev
the latest version is installed.
- name: Install the latest version of ruff
uses: astral-sh/ruff-action@v3
with:
version: "latest"
- name: Install a specific version of ruff
uses: astral-sh/ruff-action@v3
with:
version: "0.4.4"
You can specify a semver range to install the latest version that satisfies the range.
- name: Install a semver range of ruff
uses: astral-sh/ruff-action@v3
with:
version: ">=0.4.0"
- name: Pinning a minor version of ruff
uses: astral-sh/ruff-action@v3
with:
version: "0.4.x"
You can specify a file to read the version from.
Currently pyproject.toml
is supported.
- name: Install a version from a specified version file
uses: astral-sh/ruff-action@v3
with:
version-file: "my-path/to/pyproject.toml"
You can specify a checksum to validate the downloaded executable. Checksums up to the default version are automatically verified by this action. The sha256 hashes can be found on the releases page of the ruff repo.
- name: Install a specific version and validate the checksum
uses: astral-sh/ruff-action@v3
with:
version: "0.7.4"
checksum: "0de731c669b9ece77e799ac3f4a160c30849752714d9775c94cc4cfaf326860c"
This action uses the GitHub API to fetch the ruff release artifacts. To avoid hitting the GitHub API
rate limit too quickly, an authentication token can be provided via the github-token
input. By
default, the GITHUB_TOKEN
secret is used, which is automatically provided by GitHub Actions.
If the default permissions for the GitHub token are not sufficient, you can provide a custom GitHub token with the necessary permissions.
- name: Install the latest version of ruff with a custom GitHub token
uses: astral-sh/ruff-action@v3
with:
github-token: ${{ secrets.CUSTOM_GITHUB_TOKEN }}
Output | Description |
---|---|
ruff-version |
The version of Ruff that was installed. |