Depcop - Validate dependencies in package.json
Depcop is a tool to validate your dependencies
and devDependencies
in a package.json
.
It checks your source code and warns if some dependency definitions are missing,
unused, or listed in a wrong group.
Validations
Missing module check
Makes sure:
- all modules used in source code are listed in
dependencies
ordevDependencies
Unused module check
Makes sure:
dependencies
anddevDependencies
don't contain modules used in any source
Strayed module check
Makes sure:
dependencies
don't contain modules used only in development codedevDependencies
don't contain modules used in library code
Note: definition of terms
term | description |
---|---|
library code | Ordinary source files usually put in ./lib . |
development code | Test files, config files, or build scripts like gulpfile.js . |
For more details about validations, please see Validations.
Features
- ES2015 style support (
import
declarations) - CommonJS style support (
require
expressions) - Configurable
Installation
You can install Depcop using npm.
npm install --save-dev depcop
Usage
You can use Depcop via CLI or Node.js API. Please see Usage for details.
# CLI depcop --missing --unused -l 'lib/**/*.js' -d 'test/**/*.js','gulpfile.js'
// JS; const depcop = ; const result = depcop; // ..
Configuration
You can write a configuration file to configure Depcop. Please see Configuring Depcop for details.
// .depcoprc.jsmoduleexports = libSources: 'lib/**/*.js' devSources: 'test/**/*-test.js' 'gulpfile.babel.js' checks: missing: ignore: /alias.+/ unused: {} ;
Why?
It is usually difficult to notice that some dependency definitions are missing (or unused)
in local environment where necessary dependencies have been installed. Especially, it is
so difficult to notice when you accidentally define a module in devDependencies
which is
actually used in library code. In this case, all tests will pass in both of local and CI environment
where devDependencies
will be installed.
And it is not until the module is installed to user environments where
devDependencies
doesn't be installed that it causes an error for lack of dependencies.
The goal of this module is to prevent such a tragedy.
Similar projects
- dependency-check - A CLI tool to check missing or unused dependencies.
- require-lint - A CLI tool which also supports CoffeeScript.
- eslint-plugin-node - A ESLint plugin for Node.js. Linting dependencies is one of its features.