This is Productboard's maintained fork of tespkg/actions-cache. The action enables caching dependencies to S3-compatible storage, e.g. MinIO or AWS S3.
It also has a GitHub @actions/cache (v4) fallback if S3 save and restore fails.
Productboard workflows should use the pb branch:
- uses: productboard/actions-cache@pbmainmirrorsupstream/mainfromtespkg/actions-cache.pbis Productboard's maintained branch and the default branch of this repository.- Productboard changes live on
pbas a small patch stack rebased on top ofmain. - Normal pull requests must target
pb, notmain. - Do not merge upstream into
pb. Rebasepbon top ofmainwhen upstream is updated. - This fork does not run any GitHub Actions workflows. The upstream workflows
under
.github/workflows/have been removed onpbbecause they were not reliably triggered for this fork and produced no useful signal. Run tests and the build locally instead (see below).
Start every Productboard change from pb:
git fetch --all --prune
git switch -c <your-branch> origin/pbMake the change, then run the checks and rebuild generated action artifacts:
yarn install --pure-lockfile
yarn test
yarn buildCommit source changes, tests, and generated files under dist/ when they
change. Open the pull request against pb.
This fork does not use Productboard-specific tags. Do not create or move tags for testing a Productboard change. To test a change before it is merged, point the consuming workflow at your branch:
- uses: productboard/actions-cache@<your-branch>For sub-actions, use the same branch ref:
- uses: productboard/actions-cache/restore@<your-branch>
- uses: productboard/actions-cache/save@<your-branch>After the pull request is merged, consuming workflows should go back to
productboard/actions-cache@pb.
Updating from upstream is a maintainer task. First, make main mirror the
current upstream state:
git fetch --all --prune
backup_branch=main-before-upstream-sync-$(date +%Y%m%d-%H%M%S)
git branch "$backup_branch" origin/main
git push origin "$backup_branch"
git switch -C main upstream/main
git push --force-with-lease origin mainThen rebase Productboard changes on top of the updated main:
git switch -C pb origin/pb
git rebase origin/main
yarn install --pure-lockfile
yarn test
yarn build
git push --force-with-lease origin pbIf upstream has accepted a Productboard-specific fix, drop the duplicate commit
during the rebase instead of keeping the same change twice. If conflicts touch
dist/, resolve the source files first, run yarn build, and commit the
generated output.
name: dev ci
on:
push:
branches: [main]
pull_request:
branches: [main]
jobs:
build_test:
runs-on: [ubuntu-latest]
steps:
- uses: productboard/actions-cache@pb
with:
endpoint: play.min.io # optional, default s3.amazonaws.com
insecure: false # optional, use http instead of https. default false
accessKey: "Q3AM3UQ867SPQQA43P2F" # required
secretKey: "zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG" # required
sessionToken: "AQoDYXdzEJraDcqRtz123" # optional
bucket: actions-cache # required
use-fallback: true # optional, use github actions cache fallback, default true
retry: true # optional, enable retry on failure s3 operations, default false
force-save: true # optional, force save cache even the key was an exact match, will not save if the cache is read only, default false
# actions/cache compatible properties: https://github.com/actions/cache
key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
path: |
node_modules
.cache
restore-keys: |
${{ runner.os }}-yarn-You can also set env instead of using with:
- uses: productboard/actions-cache@pb
env:
AWS_ACCESS_KEY_ID: "Q3AM3UQ867SPQQA43P2F"
AWS_SECRET_ACCESS_KEY: "zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG"
# AWS_SESSION_TOKEN: "xxx"
AWS_REGION: "us-east-1"
with:
endpoint: play.min.io
bucket: actions-cache
use-fallback: false
key: test-${{ runner.os }}-${{ github.run_id }}
path: |
test-cache
~/test-cacheTo write to the cache only:
- uses: productboard/actions-cache/save@pb
with:
accessKey: "Q3AM3UQ867SPQQA43P2F" # required
secretKey: "zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG" # required
bucket: actions-cache # required
# actions/cache compatible properties: https://github.com/actions/cache
key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
path: |
node_modulesTo restore from the cache only:
- uses: productboard/actions-cache/restore@pb
with:
accessKey: "Q3AM3UQ867SPQQA43P2F" # required
secretKey: "zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG" # required
bucket: actions-cache # required
# actions/cache compatible properties: https://github.com/actions/cache
key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
path: |
node_modulesTo check if cache hits and size is not zero without downloading:
- name: Check cache
id: cache
uses: productboard/actions-cache@pb
with:
accessKey: "Q3AM3UQ867SPQQA43P2F" # required
secretKey: "zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG" # required
bucket: actions-cache # required
lookup-only: true
key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
path: |
node_modules
- name: verify cache hit
env:
CACHE_HIT: ${{ steps.cache.outputs.cache-hit }}
CACHE_SIZE: ${{ steps.cache.outputs.cache-size }}
run: |
echo "CACHE_HIT $CACHE_HIT"
echo "CACHE_SIZE $CACHE_SIZE"| Output | Description |
|---|---|
cache-hit |
A boolean value (true/false). true when an exact match is found for the primary key. |
cache-size |
Size of the cache object found, measured in bytes. |
cache-matched-key |
The key of the cache entry that was restored. On exact match this equals the input key. On a restore-keys prefix match this is the matched restore key. Empty string if no cache was found. |
restore-keys works similar to how github's @actions/cache (v4) works: It search each item in restore-keys
as prefix in object names and use the latest one
To restore from the cache using a restore-key prefix if the key restore fails:
- uses: productboard/actions-cache/restore@pb
with:
accessKey: "Q3AM3UQ867SPQQA43P2F" # required
secretKey: "zuf+tfteSlswRu7BJ86wekitnifILbZam1KYY3TG" # required
bucket: actions-cache # required
# actions/cache compatible properties: https://github.com/actions/cache
key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
restore-keys: |
${{ runner.os }}-yarn-
${{ runner.os }}-
path: |
node_modulesIf a match is found using one of the restore-keys options, then cache-hit will be FALSE but the
cache-matched-key output will be set to the key that matched. See the
actions/cache notes.
When using this with Amazon S3, the following permissions are necessary:
s3:PutObjects3:GetObjects3:ListBuckets3:GetBucketLocations3:ListBucketMultipartUploadss3:ListMultipartUploadParts