Skip to content

Workflow runs cleanup #4

Workflow runs cleanup

Workflow runs cleanup #4

Workflow file for this run

name: Workflow runs cleanup
on:
schedule:
- cron: 0 6 1 * * # at 06:00 on day-of-month 1, UTC
workflow_dispatch:
inputs:
pattern:
description: The name of workflow to clean.
type: choice
options:
- All
- Continuous delivery
- Continuous integration
- Workflow runs cleanup
default: Workflow runs cleanup
required: true
dry_run:
description: Only log actions, do not perform any delete operations.
type: boolean
required: false
reason:
description: The reason for dispatching it manually.
type: string
default: manual healthcheck
required: true
jobs:
delete:
name: Deleting
runs-on: ubuntu-latest
steps:
- name: Delete workflow runs
uses: Mattraks/delete-workflow-runs@v2
with:
token: ${{ github.token }}
repository: ${{ github.repository }}
delete_workflow_pattern: ${{ github.event.inputs.pattern || 'all' }}
dry_run: ${{ fromJSON('["", "true"]')[github.event.inputs.dry_run == 'true'] }}
retain_days: 0
keep_minimum_runs: 0
- name: Cleanup workflow runs
run: |
gh run list \
-R '${{ github.repository }}' \
--status completed \
--limit 100 \
--json databaseId \
--jq '.[] | .databaseId' |
xargs -n1 --no-run-if-empty gh run delete -R '${{ github.repository }}'
env:
GITHUB_TOKEN: ${{ github.token }}
if: github.event.inputs.pattern == 'All'
notify:
name: Notifying
needs: [ delete ]
runs-on: ubuntu-latest
if: failure() || success()
steps:
- name: Checkout the repository
uses: actions/checkout@v4
with: { fetch-depth: 0 }
- name: Send notification
uses: ./.github/actions/notify
continue-on-error: true
with:
emoji: 🧹
channel: ${{ secrets.SLACK_WEBHOOK }}
success: ${{ ! contains(needs.*.result, 'failure') }}