Skip to content

Action modifies user's npmrc #15

@honzabilek4

Description

@honzabilek4

I get the following error when using this action as github workflow using self hosted runner. It doesn't fail the build and it happens to all npm commands in the job.

Run npm ci Error: Failed to replace env in config: ${INPUT_TOKEN} at /home/ubuntu/actions-runner/_work/_tool/node/14.13.0/x64/lib/node_modules/npm/lib/config/core.js:415:13 at String.replace (<anonymous>) at envReplace (/home/ubuntu/actions-runner/_work/_tool/node/14.13.0/x64/lib/node_modules/npm/lib/config/core.js:411:12) at parseField (/home/ubuntu/actions-runner/_work/_tool/node/14.13.0/x64/lib/node_modules/npm/lib/config/core.js:389:7) at /home/ubuntu/actions-runner/_work/_tool/node/14.13.0/x64/lib/node_modules/npm/lib/config/core.js:330:24 at Array.forEach (<anonymous>) at Conf.add (/home/ubuntu/actions-runner/_work/_tool/node/14.13.0/x64/lib/node_modules/npm/lib/config/core.js:328:23) at ConfigChain.addString (/home/ubuntu/actions-runner/_work/_tool/node/14.13.0/x64/lib/node_modules/npm/node_modules/config-chain/index.js:244:8) at Conf.<anonymous> (/home/ubuntu/actions-runner/_work/_tool/node/14.13.0/x64/lib/node_modules/npm/lib/config/core.js:316:10) at /home/ubuntu/actions-runner/_work/_tool/node/14.13.0/x64/lib/node_modules/npm/node_modules/graceful-fs/graceful-fs.js:123:16 

Here's my workflow file:

name: CI on: [push, pull_request] jobs: execute: runs-on: self-hosted steps: - name: Set work folder permissions  run: pwd && sudo chown -R $USER:$USER ./ - uses: actions/checkout@v2 - name: Setup Node.js environment uses: actions/setup-node@v1.4.4 with: node-version: 14.x - name: Cache node modules uses: actions/cache@v1 env: cache-name: cache-node-modules with: path: ~/.npm # npm cache files are stored in `~/.npm` on Linux/macOS key: ${{ runner.os }}-build-${{ env.cache-name }}-${{ hashFiles('**/package-lock.json') }} restore-keys: |  ${{ runner.os }}-build-${{ env.cache-name }}-  ${{ runner.os }}-build-  ${{ runner.os }}-  - name: Install dependencies run: npm ci - name: Run linter run: npm run lint - name: Run unit tests run: npm run test  - name: Build project run: npm run build - name: Publish to npm  uses: JS-DevTools/npm-publish@v1 if: github.ref == 'refs/heads/master' with: token: ${{ secrets.NPM_AUTH_TOKEN }}

Edit:
After playing around a bit, I was able to do a workaround by setting INPUT_TOKEN to empty string.

 env: INPUT_TOKEN: '' 

Metadata

Metadata

Assignees

No one assigned

    Labels

    bugSomething isn't working

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions