Skip to content
You're viewing an older version of this GitHub Action. Do you want to see the latest version instead?
crosshair

GitHub Action

Cancel Workflows Action

v1.1.1

Cancel Workflows Action

crosshair

Cancel Workflows Action

This action will cancel any previous `waiting` workflow runs for a given workflow

Installation

Copy and paste the following snippet into your .yml file.

              

- name: Cancel Workflows Action

uses: viveklak/[email protected]

Learn more about this action in viveklak/cancel-workflows

Choose a version

typescript-action status

Cancel Superseded Workflow Runs Action

This is a Github Action that will reject or cancel workflow runs in waiting state which have been superseded by later changes based on previous commits within a branch (main by default).

When should I use this?

  1. You use Github workflows to deploy code. Specifically you use Trunk based development to allow each PR merge to progress through your deployment pipeline.
  2. You have manual approval enabled in some part of your deployment workflow, resulting in potentially multiple workflow runs stuck in waiting state
  3. You want the ability to automatically reject or cancel workflow runs which have been superseded by more recent changes

Concretely suppose PR A was merged and progressed through the pipeline until it reached a deployment to a production environment which requires manual approval. This workflow run is now in waiting state. Subsequently a bug in A was discovered and fixed in PR B which also got to the manual approval step. Now we have two workflows in waiting state. Eventually, the workflow associated with B is approved and deployed. In this case workflow run A is effectively superseded - i.e. B has all the changes of A and some additional fixes and that A should never really be deployed to production. However, the workflow run for A will stick around in waiting state until the default (and apparently unconfigurable) timeout of 30 days. Apart from being an eye-sore, this also leaves open the opportunity to accidentally approve the workflow for A which could overwrite the changes in B and unleash a bug in production 😰!

This action could be added at the end of the deployment workflow to determine all the workflow runs for a particular workflow which match the definition of superseded above. i.e.:

  1. Workflow runs triggered off the same branch but later commit than the currently approved workflow run
  2. Workflow run is currently in waiting state

Alternatively this could be added into a dispatch workflow to periodically cleanup old workflow runs

How to use it?

TODO

Acknowledgement

This Action was inspired heavily by https://github.com/styfle/cancel-workflow-action. By the authors' own admission, that action is probably now obsoleted by job and workflow level concurrency control, but the above use case is still under-served. I decided to adapt this action to the above use case.