-
Notifications
You must be signed in to change notification settings - Fork 86
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Unable to use actions/cache
with Renovate: EACCESS
#646
Comments
It looks like Line 20 in d7c9fe4
|
As mentioned in renovatebot#646, we're receiving permissions issues due to the use of the wrong UID for our user binding. Closes renovatebot#646.
@jamietanna were you able to work past this? |
@Akaame we are working around that like this:
|
Due to the size of our organisation, the recommendation from the Renovate team was to use Mend Renovate On-Prem (which is free!) and much less costly for our usages, and has its own means to do caching |
@GSala thanks this is what we also ended up doing. |
v35 will use current host user id and use |
Need to revert the default user change because of |
One can now specify the docker user. When setting this to the runner user, it seems to work fine. As I couldn't find a predefined variable/context for the current runner user/group, I added a step to determine this via We are using something similar to: - uses: actions/[email protected]
- uses: actions/[email protected]
if: github.event.inputs.repoCache != 'disabled'
with:
path: /tmp/renovate/cache
key: renovate
- name: Determine current user
id: id
run: |
echo "user=$(id -u)" >> $GITHUB_OUTPUT
echo "group=$(id -g)" >> $GITHUB_OUTPUT
- name: Generate app token
id: renovate-token
uses: getsentry/[email protected]
with:
app_id: ${{ secrets.RENOVATE_APP_ID }}
private_key: ${{ secrets.RENOVATE_APP_PRIVATE_KEY }}
- uses: renovatebot/[email protected]
with:
configurationFile: renovate.json5
token: "${{ steps.renovate-token.outputs.token }}"
docker-user: "${{ steps.id.outputs.user }}:${{ steps.id.outputs.group }}"
docker-volumes: /tmp/renovate:/tmp/renovate
env:
RENOVATE_REPOSITORY_CACHE: ${{ github.event.inputs.repoCache || 'enabled' }} |
ref: renovatebot/github-action#646 (comment) ```log DEBUG: Using platform gitAuthor: kiba-renovate[bot] <154907007+kiba-renovate[bot]@users.noreply.github.com> DEBUG: Adding token authentication for api.github.com (hostType=github) to hostRules DEBUG: Using baseDir: /tmp/renovate DEBUG: Using cacheDir: /tmp/renovate/cache DEBUG: Using containerbaseDir: /tmp/renovate/cache/containerbase FATAL: Fatal error: EACCES: permission denied, mkdir '/tmp/renovate/cache/containerbase' "err": { "errno": -13, "code": "EACCES", "syscall": "mkdir", "path": "/tmp/renovate/cache/containerbase", "message": "EACCES: permission denied, mkdir '/tmp/renovate/cache/containerbase'", "stack": "Error: EACCES: permission denied, mkdir '/tmp/renovate/cache/containerbase'" } INFO: Renovate is exiting with a non-zero code due to the following logged errors "loggerErrors": [ { "name": "renovate", "level": 60, "logContext": "f9smkP2QF64Uoz2kYhyHI", "err": { "errno": -13, "code": "EACCES", "syscall": "mkdir", "path": "/tmp/renovate/cache/containerbase", "message": "EACCES: permission denied, mkdir '/tmp/renovate/cache/containerbase'", "stack": "Error: EACCES: permission denied, mkdir '/tmp/renovate/cache/containerbase'" }, "msg": "Fatal error: EACCES: permission denied, mkdir '/tmp/renovate/cache/containerbase'" } ] Error: The process '/usr/bin/docker' failed with exit code 1 at ExecState._setResult (/home/runner/work/_actions/renovatebot/github-action/180db1547505e30c02d41959fe65ada1523ee207/dist/index.js:1702:25) at ExecState.CheckComplete (/home/runner/work/_actions/renovatebot/github-action/180db1547505e30c02d41959fe65ada1523ee207/dist/index.js:1685:18) at ChildProcess.<anonymous> (/home/runner/work/_actions/renovatebot/github-action/180db1547505e30c02d41959fe65ada1523ee207/dist/index.js:1579:27) at ChildProcess.emit (node:events:519:28) at maybeClose (node:internal/child_process:1105:16) at ChildProcess._handle.onexit (node:internal/child_process:305:5) ```
this doesn't work if you need nix manager |
When using GitHub Actions' caching functionality, Renovate ends up hitting an
EACCESS
when trying to write to the restored cache keys.A failing job with workflow definition reports the following error on subsequent runs:
It appears that:
May be at fault, as running
id -u
outside of the Renovate runner shows:Whereas we're trying to use the uid
1000
, which doesn't match, and is therefore denied from reading the files:The text was updated successfully, but these errors were encountered: