You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Sometimes in a project, there is a need to setup the development environment or enforce some policies on dependencies used in the project. However, npm doesn't provide a way to hook into its process and lifecycle scripts such as postinstall are (ab)used:
husky uses postinstall to autoinstall Git hooks and pinst to disable them in the production
postinstall-postinstall runs the app's postinstall script during its postinstall script
TBA
Furthermore, there is no way to run a script if the dependency tree of the pakcage has changed, i.e., a dependency is added or removed.
Example
As mentioned above, it can be used to setup the development environment or enforce some policies on dependencies used in the project.
How
Current Behaviour
postinstall script runs after npm install, but also runs when the package is installed as a dependency
prepare script runs after npm install, but also before the pakcage is packed
Both scripts don't run when the dependency tree is changed and there is no way to trigger a script in this case
Desired Behaviour
A new lifecycle, such as preinstalldep and postinstalldep
or, hook scripts that run before and after the dependency tree has changed (reify)
A post-reify script would be useful. We try to run a script to remove the resolved key from package-lock after any modifications because we build packages against different registries. We have some wrappers that 'know' which npm commands update the lock file, but if the wrapper is wrong or not used the lock file ends up in a dirty state. #486
Motivation ("The Why")
Sometimes in a project, there is a need to setup the development environment or enforce some policies on dependencies used in the project. However, npm doesn't provide a way to hook into its process and lifecycle scripts such as
postinstall
are (ab)used:husky
usespostinstall
to autoinstall Git hooks andpinst
to disable them in the productionpostinstall-postinstall
runs the app'spostinstall
script during itspostinstall
scriptFurthermore, there is no way to run a script if the dependency tree of the pakcage has changed, i.e., a dependency is added or removed.
Example
As mentioned above, it can be used to setup the development environment or enforce some policies on dependencies used in the project.
How
Current Behaviour
postinstall
script runs afternpm install
, but also runs when the package is installed as a dependencyprepare
script runs afternpm install
, but also before the pakcage is packedDesired Behaviour
preinstalldep
andpostinstalldep
reify
)References
Other package managers
The text was updated successfully, but these errors were encountered: