This action cancels previous runs for one or more branches/prs associated with a workflow, effectively limiting the resource consumption of the workflow to one per branch.
The easiest and most complete approach to utilize this action, is to create a separate schedule event triggered workflow, which is directed at the workflow you wish to clear duplicate runs. At each cron interval all branches and all PRs executing for either push or pull_request events will be processed and limited to one run per branch/pr.
Additionally this action can be placed as an early step in your workflow (e.g. after checkout), so that it can abort the other previously running jobs immediately, in case most resources are tied up. Unfortunately this approach is a no-op when a pull request uses a fork for a source branch. This is because the GITHUB_TOKEN provided to runs with a fork source branch specifies reed-only permissions for security reasons. write permissions are required to be able to cancel a job. Therefore, it's a good idea to only rely on this approach as a fallback in-addition to the previously described scheduling model.
- token - The github token passed from
${{ secrets.GITHUB_TOKEN }}
. Since workflow files are visible in the repository, DO NOT HARDCODE A TOKEN ONLY USE A REFERENCE. workflow - The filename of the workflow to limit runs on (only applies to schedule events) - cancelLastRunOnFailedJobs - optional array of job names which failure in the last run should also kill the last run. this can be used if you want to run jobs in parallel but kill them as soon as some of those jobs fail (similar to fail-fast matrix behaviour)
name: Cleanup Duplicate Branches and PRs
on:
schedule:
- cron: '*/15 * * * *'
cancel-runs:
# Prevent forks from running this to be nice
if: github.repository == 'foo-org/my-repo'
runs-on: ubuntu-latest
steps:
- uses: n1hility/cancel-previous-runs@v2
with:
token: ${{ secrets.GITHUB_TOKEN }}
workflow: my-heavy-workflow.yml
name: Cleanup Duplicate Branches and PRs and killing latest run with failures
on:
schedule:
- cron: '*/15 * * * *'
cancel-runs:
# Prevent forks from running this to be nice
if: github.repository == 'foo-org/my-repo'
runs-on: ubuntu-latest
steps:
- uses: n1hility/cancel-previous-runs@v2
with:
token: ${{ secrets.GITHUB_TOKEN }}
workflow: my-heavy-workflow.yml
cancelLastRunOnFailedJobs: '["static-checks", "docs"]'
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v1
- uses: n1hility/cancel-previous-runs@v2
with:
token: ${{ secrets.GITHUB_TOKEN }}
The scripts and documentation in this project are released under the MIT License