Files
xc-llm-ascend/.github/workflows/pr_close_cancel_job.yaml
Paco Xu 4f9808002b [CI] Add workflow to cancel running workflows on PR close (#5646)
Example:
https://github.com/vllm-project/vllm-ascend/actions/runs/20735955959/job/59533181655
is still running after
https://github.com/vllm-project/vllm-ascend/pull/5612 is closed.

And the action will be running for more than 2 hours, which needs to be
cleanup.

It seems that the Github Aciton will not cancel it automatically, so I
add this to cannel those PR related actions once it is closed.

Tested in https://github.com/pacoxu/pacoxu/actions/runs/20743173119.
- vLLM version: v0.13.0
- vLLM main:
2f4e6548ef

Signed-off-by: Paco Xu <roollingstone@gmail.com>
2026-01-07 15:38:10 +08:00

46 lines
1.5 KiB
YAML

name: Cancel runs on PR close
on:
pull_request:
types: [closed]
permissions:
actions: write
contents: read
jobs:
cancel:
runs-on: ubuntu-latest
steps:
- uses: actions/github-script@v7
with:
github-token: ${{ github.token }}
script: |
const { owner, repo } = context.repo;
const branch = context.payload.pull_request.head.ref;
const statuses = ["in_progress", "queued", "waiting", "pending", "requested"];
for (const status of statuses) {
let page = 1;
while (true) {
const resp = await github.rest.actions.listWorkflowRunsForRepo({
owner, repo, branch, status, per_page: 100, page
});
const runs = resp.data.workflow_runs;
if (!runs.length) break;
for (const run of runs) {
if (run.id === context.runId) continue; // don't cancel this workflow
try {
await github.rest.actions.cancelWorkflowRun({ owner, repo, run_id: run.id });
core.info(`Cancel requested: ${run.html_url}`);
} catch (e) {
// common reasons: already completed (409) or insufficient permissions (403)
core.warning(`Failed to cancel ${run.html_url}: ${e.message}`);
}
}
if (runs.length < 100) break;
page++;
}
}