9
votes

Using Github actions to publish npm package, It works and runs jest test cases without errors. So I decided to add yarn cache to optimize build time and the cache process works, but jest fails with below error.

$ jest --config=jest.config.js
/bin/sh: 1: jest: not found
error Command failed with exit code 127.
info Visit https://yarnpkg.com/en/docs/cli/run for documentation about this command.
##[error]Process completed with exit code 127.

Here is my yml

name: NPM Publish
on:
  push:
    branches: 
      - master

jobs:
  build:
    name: Build
    runs-on: ubuntu-latest
    steps:
      - uses: actions/checkout@v2
      - uses: actions/setup-node@v1
        with:
          node-version: 12.x

      - name: Get yarn cache directory
        id: yarn-cache-dir-path
        run: echo "::set-output name=dir::$(yarn cache dir)"

      - uses: actions/cache@v1
        id: yarn-cache
        with:
          path: ${{ steps.yarn-cache-dir-path.outputs.dir }}
          key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
          restore-keys: |
            ${{ runner.os }}-yarn-

      - name: Install dependencies
        if: steps.yarn-cache.outputs.cache-hit != 'true'
        run: yarn install --frozen-lockfile

      - name: Test cases
        run: yarn run pdn:test
1
Did you solve this? I suspect the issue is restoring the cached directory does not add back jest to $path, so it either needs to be added manually or called directly through its ./node_modules path - Andreas Bergström

1 Answers

0
votes

I was having a similar issue and I referred a bit of how others were doing. Maybe give this a shot

- name: Cache dependencies
  uses: actions/cache@v1
  id: yarn-cache
  with:
    path: ${{ steps.yarn-cache-dir-path.outputs.dir }}
    key: ${{ runner.os }}-yarn-${{ hashFiles('**/yarn.lock') }}
    restore-keys: |
      ${{ runner.os }}-yarn-
- name: Install Dependencies (from network)
  if: steps.cache-deps.outputs.cache-hit != 'true'
  run: |
    yarn policies set-version
    yarn install --frozen-lockfile --ignore-optional
- name: Install Dependencies (from cache)
  if: steps.cache-deps.outputs.cache-hit == 'true'
  run: |
    yarn policies set-version
    yarn install --frozen-lockfile --ignore-optional --offline