Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

npm-ensure

yibn2008204MIT1.3.0

ensure your package is good to commit/publish:

npm-ensure, check, dependencies

readme

npm-ensure

Build Status Coverage Status

ensure your package is good to commit/publish:

  • ensure npm dependencies are complete
  • ensure changelog exists

Usage

You can use npm-ensure command under the package dir which you want to check.


  Usage: npm-ensure [options]

  Options:

    -h, --help           output usage information
    -V, --version        output the version number
    -t, --types <types>  ensure check types (e.g: deps,changelog)

Example:

$ cd path/to/some-package
$ npm-ensure -t deps
==> check dependencies
The following dependencies are not defined:

 - co
 - commander

total 2 packages

$ npm-ensure -t changelog
==> check changelog
changelog for current version is NOT exists

$ npm-ensure
==> check dependencies
The following dependencies are not defined:

 - co
 - commander

total 2 packages

==> check changelog
changelog for current version is NOT exists

Or you can add it as precommit/prepublish hook to check before commit/publish.

Configration

use ensure field in package.json to config npm-ensure:

{
  "name": "foobar",
  "version": "1.1.1",
  "scripts": {
    "precommit": "npm-ensure -t deps,changelog && npm test"
  },
  "ensure": {
    "deps": {
      "checkDirs": [
        "*.js",
        "src/**/*",
        "bin/**/*"
      ],
      "ignoreDirs": [
        "src/do-not-check/**/*"
      ],
      "ignores": [
        "babel-*"
      ]
    },
    "changelog": {
      "file": "HISTORY.md"
    }
  }
}

Tips

  • deps.checkDirs, specifies which dirs/files need to be checked for dependencies
  • deps.ignoreDirs, specifies which dirs/files do NOT check
  • deps.ignores, ignore these modules when check dependencies (support glob match syntax)
  • changelog.file, specifies which file is CHANGELOG file

Work with lint-staged

Only check git staged files with lint-staged:

{
  "lint-staged": {
    "*.js": [
      "eslint --fix",
      "npm-ensure -t deps",
      "git add"
    ]
  }
}

License

MIT

changelog

1.3.0 / 2021-07-06

  • chore: bump to 1.3.0
  • feat: support ts file

1.2.0 / 2018-08-16

  • chore: bump to 1.2.0
  • feat: support lint-staged

1.1.3 / 2018-05-10

  • fix: add install guide
  • chore: bump to 1.1.3

1.1.2 / 2017-03-18

  • fix: fix incorrect logic

1.1.1 / 2017-03-18

  • fix: add peer and option deps check

1.1.0 / 2017-03-18

  • feat: add ignoreDirs support

1.0.5 / 2016-12-20

  • refactor: use dependency-analyze to parse deps

1.0.4 / 2016-11-16

  • fix: fix complex match logic

1.0.3 / 2016-11-14

  • fix: checkDeps only match files

1.0.2 / 2016-11-14

  • fix: add bin file support
  • fix: fix incorrect release

1.0.1 / 2016-11-14

  • fix: add missing bin

1.0.0 / 2016-11-14

  • init