mirror of
https://github.com/julia-actions/cache.git
synced 2026-02-13 01:46:52 +08:00
Compare commits
3 Commits
v2.0.5
...
ib/always_
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
64e2b31172 | ||
|
|
5898e5c965 | ||
|
|
1470e42d30 |
13
.github/dependabot.yml
vendored
13
.github/dependabot.yml
vendored
@@ -1,10 +1,9 @@
|
|||||||
version: 2
|
version: 2
|
||||||
|
|
||||||
updates:
|
updates:
|
||||||
- package-ecosystem: "github-actions"
|
|
||||||
directory: "/"
|
# Keep dependencies for GitHub Actions up-to-date
|
||||||
|
- package-ecosystem: 'github-actions'
|
||||||
|
directory: '/'
|
||||||
schedule:
|
schedule:
|
||||||
interval: "monthly"
|
interval: 'daily'
|
||||||
open-pull-requests-limit: 99
|
|
||||||
labels:
|
|
||||||
- "dependencies"
|
|
||||||
- "github-actions"
|
|
||||||
|
|||||||
16
.github/workflows/CI.yml
vendored
16
.github/workflows/CI.yml
vendored
@@ -59,13 +59,13 @@ jobs:
|
|||||||
env:
|
env:
|
||||||
JULIA_DEPOT_PATH: /tmp/julia-depot
|
JULIA_DEPOT_PATH: /tmp/julia-depot
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332
|
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11
|
||||||
- name: Set cache-name
|
- name: Set cache-name
|
||||||
id: cache-name
|
id: cache-name
|
||||||
shell: bash
|
shell: bash
|
||||||
run: |
|
run: |
|
||||||
echo "cache-name=${{ needs.generate-prefix.outputs.cache-prefix }}-${{ github.job }}" >>"$GITHUB_OUTPUT"
|
echo "cache-name=${{ needs.generate-prefix.outputs.cache-prefix }}-${{ github.job }}" >>"$GITHUB_OUTPUT"
|
||||||
- uses: julia-actions/setup-julia@v2
|
- uses: julia-actions/setup-julia@v1
|
||||||
with:
|
with:
|
||||||
version: ${{ matrix.version }}
|
version: ${{ matrix.version }}
|
||||||
- name: Save cache
|
- name: Save cache
|
||||||
@@ -117,8 +117,8 @@ jobs:
|
|||||||
env:
|
env:
|
||||||
JULIA_DEPOT_PATH: /tmp/julia-depot
|
JULIA_DEPOT_PATH: /tmp/julia-depot
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332
|
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11
|
||||||
- uses: julia-actions/setup-julia@v2
|
- uses: julia-actions/setup-julia@v1
|
||||||
with:
|
with:
|
||||||
version: ${{ matrix.version }}
|
version: ${{ matrix.version }}
|
||||||
- name: Restore cache
|
- name: Restore cache
|
||||||
@@ -161,7 +161,7 @@ jobs:
|
|||||||
outputs:
|
outputs:
|
||||||
cache-name: ${{ steps.cache-name.outputs.cache-name }}
|
cache-name: ${{ steps.cache-name.outputs.cache-name }}
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332
|
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11
|
||||||
- name: Set cache-name
|
- name: Set cache-name
|
||||||
id: cache-name
|
id: cache-name
|
||||||
run: |
|
run: |
|
||||||
@@ -193,7 +193,7 @@ jobs:
|
|||||||
needs: test-save-nomatrix
|
needs: test-save-nomatrix
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332
|
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11
|
||||||
- name: Restore cache
|
- name: Restore cache
|
||||||
id: cache
|
id: cache
|
||||||
uses: ./
|
uses: ./
|
||||||
@@ -233,7 +233,7 @@ jobs:
|
|||||||
outputs:
|
outputs:
|
||||||
cache-name: ${{ steps.cache-name.outputs.cache-name }}
|
cache-name: ${{ steps.cache-name.outputs.cache-name }}
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332
|
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11
|
||||||
- name: Set cache-name
|
- name: Set cache-name
|
||||||
id: cache-name
|
id: cache-name
|
||||||
run: |
|
run: |
|
||||||
@@ -259,7 +259,7 @@ jobs:
|
|||||||
needs: test-save-cloned-registry
|
needs: test-save-cloned-registry
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332
|
- uses: actions/checkout@b4ffde65f46336ab88eb53be808477a3936bae11
|
||||||
- name: Add General registry clone
|
- name: Add General registry clone
|
||||||
shell: julia --color=yes {0}
|
shell: julia --color=yes {0}
|
||||||
run: |
|
run: |
|
||||||
|
|||||||
21
README.md
21
README.md
@@ -21,8 +21,8 @@ jobs:
|
|||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v4
|
- uses: actions/checkout@v4
|
||||||
- uses: julia-actions/setup-julia@v2
|
- uses: julia-actions/setup-julia@v1
|
||||||
- uses: julia-actions/cache@v2
|
- uses: julia-actions/cache@v1
|
||||||
- uses: julia-actions/julia-buildpkg@v1
|
- uses: julia-actions/julia-buildpkg@v1
|
||||||
- uses: julia-actions/julia-runtest@v1
|
- uses: julia-actions/julia-runtest@v1
|
||||||
```
|
```
|
||||||
@@ -31,8 +31,10 @@ By default all depot directories called out below are cached.
|
|||||||
|
|
||||||
### Requirements
|
### Requirements
|
||||||
|
|
||||||
- `jq`: This action uses [`jq`](https://github.com/jqlang/jq) to parse JSON. For GitHub-hosted runners, `jq` is installed by default. On self-hosted runners and custom containers, if `jq` is not already available, this action will automatically use [`dcarbone/install-jq-action`](https://github.com/dcarbone/install-jq-action) to install `jq` (Note: `dcarbone/install-jq-action` requires that `curl` is installed; this may not always be the case in custom containers and self-hosted runners).
|
This action uses [`jq`](https://github.com/jqlang/jq) to parse JSON.
|
||||||
- `bash`: This action requires `bash`. For GitHub-hosted runners `bash` is installed by default. Self-hosted runners will need to ensure that `bash` is installed and available on the `PATH`.
|
`jq` is installed by default in GitHub-hosted runners.
|
||||||
|
[`dcarbone/install-jq-action`](https://github.com/dcarbone/install-jq-action) is used to check that `jq` is available and install it if not.
|
||||||
|
**Note:** installing `jq` with `dcarbone/install-jq-action` requires that curl is available; this may not be the case in custom containers.
|
||||||
|
|
||||||
### Optional Inputs
|
### Optional Inputs
|
||||||
|
|
||||||
@@ -45,6 +47,7 @@ By default all depot directories called out below are cached.
|
|||||||
- `cache-compiled` - Whether to cache the depot's `compiled` directory. Defaults to `true`.
|
- `cache-compiled` - Whether to cache the depot's `compiled` directory. Defaults to `true`.
|
||||||
- `cache-scratchspaces` - Whether to cache the depot's `scratchspaces` directory. Defaults to `true`.
|
- `cache-scratchspaces` - Whether to cache the depot's `scratchspaces` directory. Defaults to `true`.
|
||||||
- `cache-logs` - Whether to cache the depot's `logs` directory. Defaults to `true`. Helps auto-`Pkg.gc()` keep the cache small.
|
- `cache-logs` - Whether to cache the depot's `logs` directory. Defaults to `true`. Helps auto-`Pkg.gc()` keep the cache small.
|
||||||
|
- `save-always` - Whether to save the cache even when the job fails. Defaults to `true`. This is useful as the Julia depot should mostly be reusable from a failing job.
|
||||||
- `delete-old-caches` - Whether to delete old caches for the given key. Defaults to `true`.
|
- `delete-old-caches` - Whether to delete old caches for the given key. Defaults to `true`.
|
||||||
- `token` - A [GitHub PAT](https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/managing-your-personal-access-tokens). Defaults to `github.token`. Requires `repo` scope to enable the deletion of old caches.
|
- `token` - A [GitHub PAT](https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/managing-your-personal-access-tokens). Defaults to `github.token`. Requires `repo` scope to enable the deletion of old caches.
|
||||||
|
|
||||||
@@ -60,10 +63,6 @@ This cached file is then restored upon the second run, and afterwards resaved un
|
|||||||
The benefit of caching is that downloading one big file is quicker than downloading many different files from many different locations
|
The benefit of caching is that downloading one big file is quicker than downloading many different files from many different locations
|
||||||
and precompiling them.
|
and precompiling them.
|
||||||
|
|
||||||
By default, this action removes caches that were previously made by jobs on the same branch with the same restore key.
|
|
||||||
GitHub automatically removes old caches after a certain period or when the repository cache allocation is full.
|
|
||||||
It is, however, more efficient to explicitly remove old caches to improve caching for less frequently run jobs.
|
|
||||||
|
|
||||||
### Cache keys
|
### Cache keys
|
||||||
|
|
||||||
The cache key that the cache will be saved as is based on:
|
The cache key that the cache will be saved as is based on:
|
||||||
@@ -74,8 +73,8 @@ The cache key that the cache will be saved as is based on:
|
|||||||
- The run attempt number
|
- The run attempt number
|
||||||
|
|
||||||
> [!NOTE]
|
> [!NOTE]
|
||||||
> If there is job concurrency that is not fully defined by a matrix you should ensure that `cache-name` is
|
> If in your workflow if you do not use a matrix for concurrency you should make `cache-name` such that it is unique for
|
||||||
> unique for each concurrent job, otherwise caching may not be effective.
|
> concurrent jobs, otherwise caching may not be effective.
|
||||||
|
|
||||||
### Cache Retention
|
### Cache Retention
|
||||||
|
|
||||||
@@ -85,7 +84,7 @@ This action automatically deletes old caches that match the first 4 fields of th
|
|||||||
- The `runner.os` (may be in the matrix too, but included for safety)
|
- The `runner.os` (may be in the matrix too, but included for safety)
|
||||||
|
|
||||||
Which means your caches files will not grow needlessly. GitHub also deletes cache files after
|
Which means your caches files will not grow needlessly. GitHub also deletes cache files after
|
||||||
[7 days of not being accessed](https://docs.github.com/en/actions/using-workflows/caching-dependencies-to-speed-up-workflows#usage-limits-and-eviction-policy), and there is a limit of 10 GB for the total size of cache files associated to each repository.
|
[90 days which can be increased in private repos to up to 400 days](https://docs.github.com/en/organizations/managing-organization-settings/configuring-the-retention-period-for-github-actions-artifacts-and-logs-in-your-organization)
|
||||||
|
|
||||||
> [!NOTE]
|
> [!NOTE]
|
||||||
> To allow deletion of caches you will likely need to [grant the following permissions](https://docs.github.com/en/actions/using-jobs/assigning-permissions-to-jobs)
|
> To allow deletion of caches you will likely need to [grant the following permissions](https://docs.github.com/en/actions/using-jobs/assigning-permissions-to-jobs)
|
||||||
|
|||||||
59
action.yml
59
action.yml
@@ -36,6 +36,9 @@ inputs:
|
|||||||
cache-logs:
|
cache-logs:
|
||||||
description: Whether to cache the depot's `logs` directory. This helps automatic `Pkg.gc()` keep the cache size down.
|
description: Whether to cache the depot's `logs` directory. This helps automatic `Pkg.gc()` keep the cache size down.
|
||||||
default: 'true'
|
default: 'true'
|
||||||
|
save-always:
|
||||||
|
description: Whether to save the cache even when the job fails. This is useful as the Julia depot should mostly be reusable from a failing job.
|
||||||
|
default: 'true'
|
||||||
delete-old-caches:
|
delete-old-caches:
|
||||||
description: Whether to delete old caches for the given key.
|
description: Whether to delete old caches for the given key.
|
||||||
default: 'true'
|
default: 'true'
|
||||||
@@ -52,7 +55,7 @@ runs:
|
|||||||
using: 'composite'
|
using: 'composite'
|
||||||
steps:
|
steps:
|
||||||
- name: Install jq
|
- name: Install jq
|
||||||
uses: dcarbone/install-jq-action@8867ddb4788346d7c22b72ea2e2ffe4d514c7bcb
|
uses: dcarbone/install-jq-action@8867ddb4788346d7c22b72ea2e2ffe4d514c7bcb # v2.1.0
|
||||||
with:
|
with:
|
||||||
force: false # Skip install when an existing `jq` is present
|
force: false # Skip install when an existing `jq` is present
|
||||||
|
|
||||||
@@ -66,11 +69,6 @@ runs:
|
|||||||
else
|
else
|
||||||
depot="~/.julia"
|
depot="~/.julia"
|
||||||
fi
|
fi
|
||||||
if [[ "$OSTYPE" == "msys" || "$OSTYPE" == "cygwin" ]]; then
|
|
||||||
depot="${depot/#\~/$USERPROFILE}" # Windows paths
|
|
||||||
else
|
|
||||||
depot="${depot/#\~/$HOME}" # Unix-like paths
|
|
||||||
fi
|
|
||||||
echo "depot=$depot" | tee -a "$GITHUB_OUTPUT"
|
echo "depot=$depot" | tee -a "$GITHUB_OUTPUT"
|
||||||
|
|
||||||
cache_paths=()
|
cache_paths=()
|
||||||
@@ -80,7 +78,7 @@ runs:
|
|||||||
[ "${{ inputs.cache-packages }}" = "true" ] && cache_paths+=("$packages_path")
|
[ "${{ inputs.cache-packages }}" = "true" ] && cache_paths+=("$packages_path")
|
||||||
registries_path="${depot}/registries"
|
registries_path="${depot}/registries"
|
||||||
if [ "${{ inputs.cache-registries }}" = "true" ]; then
|
if [ "${{ inputs.cache-registries }}" = "true" ]; then
|
||||||
if [ ! -d "${registries_path}" ]; then
|
if [ ! -d "${registries_path/#\~/$HOME}" ]; then
|
||||||
cache_paths+=("$registries_path")
|
cache_paths+=("$registries_path")
|
||||||
else
|
else
|
||||||
echo "::warning::Julia depot registries already exist. Skipping restoring of cached registries to avoid potential merge conflicts when updating. Please ensure that \`julia-actions/cache\` precedes any workflow steps which add registries."
|
echo "::warning::Julia depot registries already exist. Skipping restoring of cached registries to avoid potential merge conflicts when updating. Please ensure that \`julia-actions/cache\` precedes any workflow steps which add registries."
|
||||||
@@ -128,6 +126,7 @@ runs:
|
|||||||
key: ${{ steps.keys.outputs.key }}
|
key: ${{ steps.keys.outputs.key }}
|
||||||
restore-keys: ${{ steps.keys.outputs.restore-key }}
|
restore-keys: ${{ steps.keys.outputs.restore-key }}
|
||||||
enableCrossOsArchive: false
|
enableCrossOsArchive: false
|
||||||
|
save-always: ${{ inputs.save-always }}
|
||||||
|
|
||||||
# if it wasn't restored make the depot anyway as a signal that this action ran
|
# if it wasn't restored make the depot anyway as a signal that this action ran
|
||||||
# for other julia actions to check, like https://github.com/julia-actions/julia-buildpkg/pull/41
|
# for other julia actions to check, like https://github.com/julia-actions/julia-buildpkg/pull/41
|
||||||
@@ -137,44 +136,12 @@ runs:
|
|||||||
du -shc ${{ steps.paths.outputs.depot }}/* || true
|
du -shc ${{ steps.paths.outputs.depot }}/* || true
|
||||||
shell: bash
|
shell: bash
|
||||||
|
|
||||||
# issue https://github.com/julia-actions/cache/issues/110
|
# github and actions/cache doesn't provide a way to update a cache at a given key, so we delete any
|
||||||
# Pkg may not run `Registry.update()` if a manifest exists, which may exist because of a
|
# that match the restore key just before saving the new cache
|
||||||
# `Pkg.dev` call or because one is added to the repo. So be safe and update cached registries here.
|
|
||||||
# Older (~v1.0) versions of julia that don't have `Pkg.Registry.update()` seem to always update registries in
|
|
||||||
# Pkg operations. So this is only necessary for newer julia versions.
|
|
||||||
- name: Update any cached registries
|
|
||||||
if: ${{ inputs.cache-registries == 'true' }}
|
|
||||||
continue-on-error: true
|
|
||||||
run: |
|
|
||||||
if [ -d "${{ steps.paths.outputs.depot }}/registries" ] && [ -n "$(ls -A "${{ steps.paths.outputs.depot }}/registries")" ]; then
|
|
||||||
echo "Registries directory exists and is non-empty. Updating any registries"
|
|
||||||
julia -e "import Pkg; isdefined(Pkg, :Registry) && Pkg.Registry.update();"
|
|
||||||
else
|
|
||||||
echo "Registries directory does not exist or is empty. Skipping registry update"
|
|
||||||
fi
|
|
||||||
shell: bash
|
|
||||||
|
|
||||||
# GitHub actions cache entries are immutable and cannot be updated. In order to have both the Julia
|
|
||||||
# depot cache be up-to-date and avoid storing redundant cache entries we'll manually cleanup old
|
|
||||||
# cache entries before the new cache is saved. However, we need to be careful with our manual
|
|
||||||
# cleanup as otherwise we can cause cache misses for jobs which would have normally had a cache hit.
|
|
||||||
# Some scenarios to keep in mind include:
|
|
||||||
#
|
|
||||||
# - Job failures result in the post-action for `actions/cache` being skipped. If we delete all cache
|
|
||||||
# entries for the branch we may have no cache entry available for the next run.
|
|
||||||
# - We should avoid deleting old cache entries for the default branch since these entries serve as
|
|
||||||
# the fallback if no earlier cache entry exists on a branch. We can rely on GitHub's default cache
|
|
||||||
# eviction policy here which will remove the oldest cache entry first.
|
|
||||||
#
|
|
||||||
# References:
|
|
||||||
# - https://github.com/actions/cache/blob/main/tips-and-workarounds.md#update-a-cache
|
|
||||||
# - https://docs.github.com/en/actions/using-workflows/caching-dependencies-to-speed-up-workflows#usage-limits-and-eviction-policy
|
|
||||||
|
|
||||||
# Not windows
|
# Not windows
|
||||||
- uses: pyTooling/Actions/with-post-step@e9d0dc3dba9fda45f195946858708f60c0240caf # v1.0.5
|
- uses: pyTooling/Actions/with-post-step@adef08d3bdef092282614f3b683897cefae82ee3
|
||||||
if: ${{ inputs.delete-old-caches != 'false' &&
|
if: ${{ inputs.delete-old-caches != 'false' && runner.OS != 'Windows' }}
|
||||||
github.ref != format('refs/heads/{0}', github.event.repository.default_branch) &&
|
|
||||||
runner.OS != 'Windows' }}
|
|
||||||
with:
|
with:
|
||||||
# seems like there has to be a `main` step in this action. Could list caches for info if we wanted
|
# seems like there has to be a `main` step in this action. Could list caches for info if we wanted
|
||||||
# main: julia ${{ github.action_path }}/handle_caches.jl "${{ github.repository }}" "list"
|
# main: julia ${{ github.action_path }}/handle_caches.jl "${{ github.repository }}" "list"
|
||||||
@@ -184,10 +151,8 @@ runs:
|
|||||||
GH_TOKEN: ${{ inputs.token }}
|
GH_TOKEN: ${{ inputs.token }}
|
||||||
|
|
||||||
# Windows (because this action uses command prompt on windows)
|
# Windows (because this action uses command prompt on windows)
|
||||||
- uses: pyTooling/Actions/with-post-step@e9d0dc3dba9fda45f195946858708f60c0240caf # v1.0.5
|
- uses: pyTooling/Actions/with-post-step@adef08d3bdef092282614f3b683897cefae82ee3
|
||||||
if: ${{ inputs.delete-old-caches != 'false' &&
|
if: ${{ inputs.delete-old-caches != 'false' && runner.OS == 'Windows' }}
|
||||||
github.ref != format('refs/heads/{0}', github.event.repository.default_branch) &&
|
|
||||||
runner.OS == 'Windows' }}
|
|
||||||
with:
|
with:
|
||||||
main: echo ""
|
main: echo ""
|
||||||
post: cd %GITHUB_ACTION_PATH% && julia handle_caches.jl rm "${{ github.repository }}" "${{ steps.keys.outputs.restore-key }}" "${{ github.ref }}" "${{ inputs.delete-old-caches != 'required' }}"
|
post: cd %GITHUB_ACTION_PATH% && julia handle_caches.jl rm "${{ github.repository }}" "${{ steps.keys.outputs.restore-key }}" "${{ github.ref }}" "${{ inputs.delete-old-caches != 'required' }}"
|
||||||
|
|||||||
@@ -1,56 +0,0 @@
|
|||||||
# Making a new release
|
|
||||||
|
|
||||||
In this guide, as an example, `v2.2.0` refers to the version number of the new release that you want to make.
|
|
||||||
|
|
||||||
## Part 1: Use the Git CLI to create and push the Git tags
|
|
||||||
|
|
||||||
Step 1: Create a new lightweight tag of the form `vMAJOR.MINOR.PATCH`.
|
|
||||||
|
|
||||||
```bash
|
|
||||||
git clone git@github.com:julia-actions/cache.git
|
|
||||||
cd cache
|
|
||||||
git fetch --all --tags
|
|
||||||
|
|
||||||
git checkout main
|
|
||||||
|
|
||||||
git --no-pager log -1
|
|
||||||
# Take note of the commit hash here.
|
|
||||||
|
|
||||||
# Now, create a new lightweight tag of the form `vMAJOR.MINOR.PATCH`.
|
|
||||||
#
|
|
||||||
# Replace `commit_hash` with the commit hash that you obtained from the
|
|
||||||
# `git log -1` step.
|
|
||||||
#
|
|
||||||
# Replace `v2.2.0` with the actual version number that you want to use.
|
|
||||||
git tag v2.2.0 commit_hash
|
|
||||||
```
|
|
||||||
|
|
||||||
Step 2: Once you've created the new release, you need to update the `v2` tag to point to the new release. For example, suppose that the previous release was `v2.1.0`, and suppose that you just created the new release `v2.2.0`. You need to update the `v2` tag so that it points to `v2.2.0`. Here are the commands:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
# Create/update the new v2 tag locally, where the new v2 tag will point to the
|
|
||||||
# release that you created in the previous step.
|
|
||||||
#
|
|
||||||
# Make sure to change `v2.2.0` to the actual value for the tag that you just
|
|
||||||
# created in the previous step.
|
|
||||||
#
|
|
||||||
# The `-f` flag forcibly overwrites the old
|
|
||||||
# `v2` tag (if it exists).
|
|
||||||
git tag -f v2 v2.2.0
|
|
||||||
```
|
|
||||||
|
|
||||||
Step 3: Now you need to push the tags:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
# Regular-push the new `v2.2.0` tag:
|
|
||||||
git push origin tag v2.2.0
|
|
||||||
|
|
||||||
# Force-push the new v2 tag:
|
|
||||||
git push origin tag v2 --force
|
|
||||||
```
|
|
||||||
|
|
||||||
## Part 2: Create the GitHub Release
|
|
||||||
|
|
||||||
Go to the [Releases](https://github.com/julia-actions/cache/releases) section of this repo and create a new release (using the GitHub web interface).
|
|
||||||
|
|
||||||
For the "choose a tag" drop-down field, select the `v2.2.0` tag that you created and pushed in Part 1 of this guide.
|
|
||||||
@@ -10,48 +10,37 @@ function handle_caches()
|
|||||||
repo, restore_key, ref = ARGS[2:4]
|
repo, restore_key, ref = ARGS[2:4]
|
||||||
allow_failure = ARGS[5] == "true"
|
allow_failure = ARGS[5] == "true"
|
||||||
|
|
||||||
|
endpoint = "/repos/$repo/actions/caches"
|
||||||
page = 1
|
page = 1
|
||||||
per_page = 100
|
per_page = 100
|
||||||
skipped = String[]
|
escaped_restore_key = replace(restore_key, "\"" => "\\\"")
|
||||||
deleted = String[]
|
query = ".actions_caches[] | select(.key | startswith(\"$escaped_restore_key\")) | .id"
|
||||||
failed = String[]
|
|
||||||
|
deletions = String[]
|
||||||
|
failures = String[]
|
||||||
while 1 <= page <= 5 # limit to avoid accidental rate limiting
|
while 1 <= page <= 5 # limit to avoid accidental rate limiting
|
||||||
# https://docs.github.com/en/rest/actions/cache?apiVersion=2022-11-28#list-github-actions-caches-for-a-repository
|
cmd = `gh api -X GET $endpoint -F ref=$ref -F per_page=$per_page -F page=$page --jq $query`
|
||||||
# Note: The `key` field matches on the full key or a prefix.
|
|
||||||
cmd = ```
|
|
||||||
gh api -X GET /repos/$repo/actions/caches
|
|
||||||
--field per_page=$per_page
|
|
||||||
--field page=$page
|
|
||||||
--field ref=$ref
|
|
||||||
--field key=$restore_key
|
|
||||||
--field sort=last_accessed_at
|
|
||||||
--field direction=desc
|
|
||||||
--jq '.actions_caches[].id'
|
|
||||||
```
|
|
||||||
ids = split(read(cmd, String); keepempty=false)
|
ids = split(read(cmd, String); keepempty=false)
|
||||||
|
page = length(ids) == per_page ? page + 1 : -1
|
||||||
|
|
||||||
# Avoid deleting the latest used cache entry. This is particularly important for
|
# We can delete all cache entries on this branch that matches the restore key
|
||||||
# job failures where a new cache entry will not be saved after this.
|
# because the new cache is saved later.
|
||||||
page == 1 && !isempty(ids) && push!(skipped, popfirst!(ids))
|
|
||||||
|
|
||||||
for id in ids
|
for id in ids
|
||||||
try
|
try
|
||||||
run(`gh cache delete $id --repo $repo`)
|
run(`gh cache delete $id --repo $repo`)
|
||||||
push!(deleted, id)
|
push!(deletions, id)
|
||||||
catch e
|
catch e
|
||||||
@error e
|
@error e
|
||||||
push!(failed, id)
|
push!(failures, id)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
page = length(ids) == per_page ? page + 1 : -1
|
|
||||||
end
|
end
|
||||||
if isempty(skipped) && isempty(deleted) && isempty(failed)
|
if isempty(failures) && isempty(deletions)
|
||||||
println("No existing caches found on ref `$ref` matching restore key `$restore_key`")
|
println("No existing caches found on ref `$ref` matching restore key `$restore_key`")
|
||||||
else
|
else
|
||||||
if !isempty(failed)
|
if !isempty(failures)
|
||||||
println("Failed to delete $(length(failed)) existing caches on ref `$ref` matching restore key `$restore_key`")
|
println("Failed to delete $(length(failures)) existing caches on ref `$ref` matching restore key `$restore_key`")
|
||||||
println.(failed)
|
println.(failures)
|
||||||
@info """
|
@info """
|
||||||
To delete caches you need to grant the following to the default `GITHUB_TOKEN` by adding
|
To delete caches you need to grant the following to the default `GITHUB_TOKEN` by adding
|
||||||
this to your workflow:
|
this to your workflow:
|
||||||
@@ -66,9 +55,9 @@ function handle_caches()
|
|||||||
"""
|
"""
|
||||||
allow_failure || exit(1)
|
allow_failure || exit(1)
|
||||||
end
|
end
|
||||||
if !isempty(deleted)
|
if !isempty(deletions)
|
||||||
println("Deleted $(length(deleted)) caches on ref `$ref` matching restore key `$restore_key`")
|
println("Deleted $(length(deletions)) caches on ref `$ref` matching restore key `$restore_key`")
|
||||||
println.(deleted)
|
println.(deletions)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
|
|||||||
Reference in New Issue
Block a user