Select CLI Version:
npm ci
This command is similar to npm install, except it's meant to be used in automated environments such as test platforms, continuous integration, and deployment -- or any situation where you want to make sure you're doing a clean install of your dependencies.
npm ci will be significantly faster when:
package-lock.json or npm-shrinkwrap.json file.node_modules folder is missing or empty.In short, the main differences between using npm install and npm ci are:
package-lock.json or npm-shrinkwrap.json.package.json, npm ci will exit with an error, instead of updating the package lock.npm ci can only install entire projects at a time: individual dependencies cannot be added with this command.node_modules is already present, it will be automatically removed before npm ci begins its install.package.json or any of the package-locks: installs are essentially frozen.Make sure you have a package-lock and an up-to-date install:
$ cd ./my/npm/project$ npm installadded 154 packages in 10s$ ls | grep package-lock
Run npm ci in that project
$ npm ciadded 154 packages in 5s
Configure Travis to build using npm ci instead of npm install:
# .travis.ymlinstall:- npm ci# keep the npm cache around to speed up installscache:directories:- "$HOME/.npm"
auditWhen "true" submit audit reports alongside the current npm command to the default registry and all registries configured for scopes. See the documentation for npm audit for details on what is submitted.
ignore-scriptsIf true, npm does not run scripts specified in package.json files.
Note that commands explicitly intended to run a particular script, such as npm start, npm stop, npm restart, npm test, and npm run-script will still run their intended script if ignore-scripts is set, but they will not run any pre- or post-scripts.
script-shellThe shell to use for scripts run with the npm exec, npm run and npm init <pkg> commands.