Skip to content

Latest commit

 

History

History
73 lines (45 loc) · 3.88 KB

File metadata and controls

73 lines (45 loc) · 3.88 KB

verify-npm-package

Verifies the source files of a NodeJS package - by running its verify script within the scripts section of package.json.

It is worth noting this action can support any technology - as long as you comply with the requirements described below.

Example

steps:
  - uses: actions/checkout@v4

  - uses: giancosta86/aurora-github/actions/verify-npm-package@v7

IMPORTANT: please, remember to declare your verification process in the verify script within package.json! For example:

"scripts": {
  "test": "vitest",
  "build": "tsc",
  "verify": "pnpm test && pnpm build"
}

How it works

  1. Run enforce-branch-version, forwarding the enforce-branch-version input to its mode input.

  2. Ensure that the package is based on ESM - via the "type": "module" attribute in package.json; this default behavior can be disabled.

  3. Install the required NodeJS version, pnpm and the dependencies, via setup-nodejs-context

  4. Run pnpm verify - so that the related script in package.json can decide what to do.

  5. By default, run check-subpath-exports to verify that the exports field in package.json actually references existing files.

  6. If a tests directory exists within project-directory, execute run-custom-tests on it, with the optional flag enabled.

    💡The rationale for this step is a parallelism with Rust's tests directory - dedicated to verify the crate under test from a client perspective; however, in verify-npm-package you have even more fine-grained control over the test process: for example, you can automatically launch a Bash script to test the system, while still relying on the tests directory to host utility modules imported by different tests in the src directory tree.

    Please, note: should you need to execute a shell script for testing, a verify.sh script, run by Bash, is required; for further details, please refer to run-custom-tests.

  7. Find critical TODOs in the source code - which crash the workflow by default.

Requirements

  • The entire verification process for the package must be triggered by the verify script in package.json (see the example).

  • The requirements for setup-nodejs-context.

Inputs 📥

Name Type Description Default value
crash-on-critical-todos boolean Crash the workflow if critical TODOs are found true
source-file-regex string PCRE pattern describing the source files view source
enforce-branch-version inject,check,skip How the branch version should be enforced inject
enforce-esm boolean Verify that the package.json type field is module true
check-subpath-exports boolean Run check-subpath-exports after the verify script true
project-directory string The directory containing package.json .

Further references