From 9a59119163b4b4223fbd3561c746d11cd91b6d92 Mon Sep 17 00:00:00 2001 From: Jiahao XU Date: Thu, 23 Mar 2023 00:50:13 +1100 Subject: [PATCH] Fully remove all caches for PR in `cache-cleanup.yml` (#942) Previously it only removes 30 caches for the PR because gh actions-cache list defaults to only listing 30 cache entries. In this PR, I changed the limit to the maximum allowed 100 cache entries and I also added a loop to keep getting the next 100 cache entries until there is none. Signed-off-by: Jiahao XU --- .github/workflows/cache-cleanup.yml | 27 +++++++++++++++++---------- 1 file changed, 17 insertions(+), 10 deletions(-) diff --git a/.github/workflows/cache-cleanup.yml b/.github/workflows/cache-cleanup.yml index 23de39f3..fd6bc47e 100644 --- a/.github/workflows/cache-cleanup.yml +++ b/.github/workflows/cache-cleanup.yml @@ -12,19 +12,26 @@ jobs: - name: Cleanup run: | gh extension install actions/gh-actions-cache - - REPO=${{ github.repository }} + + REPO="${{ github.repository }}" BRANCH="refs/pull/${{ github.event.pull_request.number }}/merge" - echo "Fetching list of cache key" - cacheKeysForPR=$(gh actions-cache list -R $REPO -B $BRANCH | cut -f 1 ) + while true; do + echo "Fetching list of cache key" + cacheKeysForPR="$(gh actions-cache list -R "$REPO" -B "$BRANCH" -L 100 | cut -f 1 )" - ## Setting this to not fail the workflow while deleting cache keys. - set +e - echo "Deleting caches..." - for cacheKey in $cacheKeysForPR - do - gh actions-cache delete $cacheKey -R $REPO -B $BRANCH --confirm + if [ -z "$cacheKeysForPR" ]; then + break + fi + + ## Setting this to not fail the workflow while deleting cache keys. + set +e + echo "Deleting caches..." + for cacheKey in $cacheKeysForPR + do + echo Removing "$cacheKey" + gh actions-cache delete "$cacheKey" -R "$REPO" -B "$BRANCH" --confirm + done done echo "Done" env: