Git hooks made easy [evacuated from NSA/Microsoft github]

PombaM 4378d180b7 Update README.md (#132) il y a 7 ans
bin cb50cae56a Update il y a 7 ans
src 9321e7adf9 Don't load nvm if it's already loaded il y a 7 ans
test 244a6086c8 Make it easier to migrate from ghooks il y a 7 ans
.gitignore a2b447c88d First commit il y a 10 ans
.npmignore b330a22e44 Add .npmignore (#127) il y a 7 ans
.travis.yml 83f9a21ac6 Update .travis.yml il y a 7 ans
CHANGELOG.md 4bf6014ab0 Update CHANGELOG.md il y a 7 ans
HOOKS.md 407c6f60a2 Add missing hooks (Fix issue #52) (#62) il y a 8 ans
LICENSE a2b447c88d First commit il y a 10 ans
README.md 4378d180b7 Update README.md (#132) il y a 7 ans
package.json 5c6d1e6333 0.13.4 il y a 7 ans

README.md

husky npm version Build Status

Git hooks made easy

Husky can prevent bad commit, push and more :dog: woof!

Install

npm install husky --save-dev
// Edit package.json
{
  "scripts": {
    "precommit": "npm test",
    "prepush": "npm test",
    "...": "..."
  }
}
git commit -m "Keep calm and commit"

Existing hooks aren't replaced and you can use any Git hook.

If you're migrating from ghooks, simply run npm uninstall ghooks --save-dev && npm install husky --save-dev and edit package.json. Husky will automatically migrate ghooks hooks.

Used by

Uninstall

npm uninstall husky --save-dev

Tricks

Debug hooks easily

If you need to debug hooks, simply use npm run <script-name>. For example:

npm run precommit

Git GUI clients support

If you've installed Node using the standard installer, nvm or homebrew, Git hooks will be executed in GUI applications.

Working with multiple version of Node

If nvm is installed, husky will try to use the default/current installed Node version or use the project .nvmrc.

Tip to use the system-installed version of node, nvm provides a system alias

Accessing Git params

Git params can be found in GIT_PARAMS environment variable.

Setting a different log level

By default, husky will run scripts using --silent to make the output more readable. If you want to override this, simply pass a different log level to your scripts:

"precommit": "npm run some-script -q"

-q/--quiet is equivalent to --loglevel warn which is npm default log level.

Git submodule support

Yes

Cygwin support

Yes

Yarn support

Please use yarn v0.24+

See also

  • pkg-ok - prevents publishing modules with bad paths

License

MIT - Typicode :cactus: