Sloth is a GitHub Action designed to optimize and streamline continuous integration suites by acting as the final arbiter for their success. It patiently waits for all other checks to conclude, providing its seal of approval only if all triggered jobs were successful. Sloth bridges a functionality gap within GitHub Actions, allowing for required checks to be dynamic, a feature not natively supported.
Sloth is invaluable in the following scenarios:
- Conditional Triggers with Mandatory Success: Sloth is invaluable when you need to trigger a check conditionally, but mandate its success if triggered. For instance:
- Linting GitHub Action workflows selectively when they are modified.
- Running checks only for services modified within a monorepo.
- Large Matrix of Checks: Sloth simplifies the management of extensive check matrices, alleviating the burden of maintaining which checks are required.
To integrate Sloth, follow these steps:
- Create Workflow: Sloth runs as a separate workflow. See the example definition below for a copyable workflow file.
- Set as Required Check: Configure Sloth as the primary (often sole) required check in your branch protection rules. This ensures that the entire suite is contingent upon Sloth's validation.
name: Sloth
on:
pull_request:
merge_group:
jobs:
sloth:
runs-on: ubuntu-22.04
steps:
- name: Sloth
uses: lendable/sloth@v0
with:
token: ${{ secrets.GITHUB_TOKEN }}
Name | Description | Required | Default |
---|---|---|---|
token |
GitHub token to use to interact with the GitHub API, unless you have rate limit concerns this should be ${{ secrets.GITHUB_TOKEN }} . |
Yes | |
ref |
Git reference to inspect check runs for. The default supports Pull Requests, Merge Queues as well as branch pushes. | No | ${{ github.event.pull_request.head.sha || github.sha }} |
interval |
The number of seconds in between polls of the GitHub API for check run conclusions. | No | 10 |
timeout |
The number of seconds before the job is declared a failure if check runs have not yet concluded. | No | 600 |
name |
The name of Sloth's own check run. This is used to ensure Sloth does not wait upon itself. | No | "sloth" |
ignored |
A multi-line list of check run names to ignore when determining an overall result. | No | "" |