Skip to content
This repository has been archived by the owner on Aug 13, 2022. It is now read-only.
/ gha-npm-cache Public archive
generated from c-hive/js-boilerplate

1-liner npm install cache for GitHub Actions

License

Notifications You must be signed in to change notification settings

c-hive/gha-npm-cache

Use this GitHub action with your project
Add this Action to an existing workflow or create a new one
View on Marketplace

Repository files navigation

Deprecated

This functionality is now part of actions/setup-node:

- name: Setup Node.js
  uses: actions/setup-node@v3
  with:
    node-version: '16'
    cache: 'npm'

gha-npm-cache

1-liner npm install cache for GitHub Actions

Status and support

  • ✔ stable
  • ✖ not supported
  • ✖ no ongoing development

CI

GitHub Action caches improve build times and reduce network dependencies. However, writing the correct cache logic is tricky. You need to understand how the cache action (keys and restore keys) work. Did you know you're not supposed to cache the node_modules folder? The setup is different per OS and takes a lot of space in your workflows. Not anymore!

gha-npm-cache is a simple 1-liner that covers all use-cases, correctly:

Usage

Add this step before npm install:

- uses: c-hive/gha-npm-cache@v1

For example:

.github/workflows/ci.yml

name: CI

on: [push]

jobs:
  lint:
    runs-on: ubuntu-latest
    steps:
    - uses: actions/checkout@v1

    - uses: c-hive/gha-npm-cache@v1
      # with:
        # directory: server # Optional, specify the folder of package-lock.json if not in the root directory

    - name: Install JS dependencies
      run: npm install
    - name: Test
      run: npm run test

Solution comparison

Native

- name: Get npm cache directory
  id: npm-cache
  run: |
    echo "::set-output name=dir::$(npm config get cache)"
- uses: actions/cache@v1
  with:
    path: ${{ steps.npm-cache.outputs.dir }}
    key: ${{ runner.os }}-node-${{ hashFiles('**/package-lock.json') }}
    restore-keys: |
      ${{ runner.os }}-node-

gha-npm-cache

- uses: c-hive/gha-npm-cache@v1

Similar actions

Conventions

This project follows C-Hive guides for code style, way of working and other development concerns.

License

The project is available as open source under the terms of the MIT License.

About

1-liner npm install cache for GitHub Actions

Resources

License

Stars

Watchers

Forks

Sponsor this project

 

Packages

No packages published