Manage node packages on your Github Action repository.
You must include the YAML configuration file in your repository. If you don't specify its path to the config
key in your workflow, the action will try to find it in your .github
directory and then in root (./
) .
Any of the following are accepted config file names.
npmworker.config.yaml
npmworker.config.yml
npm.worker.config.yaml
npm.worker.config.yml
- Here we specify the workflow should only run when a change to our config file is made.
# ./.github/workflows/npmworker.yaml
name: NPM Worker
on:
push:
branches:
- master:
paths:
- ./path/to/npmworker.config.yaml
jobs:
npm:
runs-on: ubuntu-latest
name: NPM Worker
steps:
- uses: actions/checkout@v2
- name: Worker
uses: mudlabs/npm-worker@1.3.0
with:
# OPTIONAL: Provide a PAT for the repository, so the
# action can log activity to an issue.
# Default: github.token
token: ${{ secrets.GITHUB_TOKEN }}
# OPTIONAL: Provide a path within your repository to
# the YAML configuration file.
# If not provided the action will attempt to find it
# before failing.
config: ./path/to/npmworker.config.yaml
- If you want to remove a package it's not enough to remove it from the
install
array, you need to add it to theuninstall
array.
Prop | Description | Default |
---|---|---|
clean |
Specifies the action should edit the configuration file apon execution. This way every time you update the file it's a clean list of commands. Only the install , update , and uninstall arrays will be emptied, and they will be regardless of the package execution outcome. |
false |
init |
Specifies the action should create a package.json file at path if one is not there. If the package does need to init, it will do so using npm init -y . |
true |
issue |
You may provide an issue number to track activity. If set this action will post comments to the issue detailing what has changed, whenever it runs. For an example of what these comments will look like see the Test Logs issue. | |
path |
Specifies a path from your repository root, where you would like node_modules located. | ./ |
install |
An array of npm packages you want installed. | |
update |
An array of packages to update, or install if they are not installed. | |
uninstall |
An array of packages to uninstall. |
# Example Configuration
clean: true
init: true
issue: 1
path: ./dis
install:
- "@actions/github"
- unirest
update:
- cardinal-direction
uninstall:
- node-fetch
Prop | Description |
---|---|
activity |
A markdown flavourd description of the activity performed by the action. If an issue number is specified within the configuration file, this is the comment sent to that issue. |
- If you want the
node_modules
andpackages
to persist on your repository you will need to commit the changes. I recommend using the Add and Commit action for this. - You can not chain executions. Each array item is checked for, and broken at any instance of
&&
. - Each array item is executed as
npm x item
(i.e. npm install unirest).