Skip to content

[RRFC] Development lifecycle scripts (hooks) #460

Open
@ylemkimon

Description

@ylemkimon

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 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)

References

Other package managers

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions