Update dependency husky to v9
This MR contains the following updates:
Package | Type | Update | Change |
---|---|---|---|
husky | devDependencies | major | ^4.3.8 -> ^9.0.0 |
Release Notes
typicode/husky (husky)
v9.1.7
What's Changed
- fix: add husky label to deprecated warning by @smackfu in https://github.com/typicode/husky/pull/1538
New Contributors
- @smackfu made their first contribution in https://github.com/typicode/husky/pull/1538
Full Changelog: https://github.com/typicode/husky/compare/v9.1.6...v9.1.7
v9.1.6
What's Changed
- Fix issue where example pre-commit file is generated incorrectly by @dexmlee in https://github.com/typicode/husky/pull/1519
New Contributors
- @OlegKipchatov made their first contribution in https://github.com/typicode/husky/pull/1495
- @Byron2016 made their first contribution in https://github.com/typicode/husky/pull/1499
- @dexmlee made their first contribution in https://github.com/typicode/husky/pull/1519
Full Changelog: https://github.com/typicode/husky/compare/v9.1.5...v9.1.6
v9.1.5
What's Changed
- fixes #1494, support
pre-merge-commit
hook by @RainMeoCat in https://github.com/typicode/husky/pull/1497
New Contributors
- @RainMeoCat made their first contribution in https://github.com/typicode/husky/pull/1497
Full Changelog: https://github.com/typicode/husky/compare/v9.1.4...v9.1.5
v9.1.4
- Improve deprecation notice
v9.1.3
- fix: better handle space in
PATH
v9.1.2
Show a message instead of automatically removing deprecated code.
This only concerns projects that still have the following code in their hooks:
- #!/usr/bin/env sh # <- This is deprecated, remove it
- . "$(dirname -- "$0")/_/husky.sh" # <- This is deprecated, remove it
### Rest of your hook code
Hooks with these lines will fail in v10.0.0
v9.1.1
Super saiyan god dog! It's over 9.0.0!
What's new
You can now run package commands directly, no need for npx
or equivalents.
It makes writing hooks more intuitive and is also slightly faster
### .husky/pre-commit
- npx jest
+ jest # ~0.2s faster
A new recipe has been added to the docs. Lint staged files without external dependencies (inspired by Prettier docs). Feel free to modify it.
### .husky/pre-commit
prettier $(git diff --cached --name-only --diff-filter=ACMR | sed 's| |\\ |g') --write --ignore-unknown
git update-index --again
For more advanced use cases, see lint-staged.
Fixes
-
bunx husky init
command - Workaround for some hooks implementation on Windows
Deprecations
-
#!/usr/bin/env sh
and. "$(dirname -- "$0")/_/husky.sh"
are deprecated.husky
command will automatically remove them, no action required. - If you're having code in
~/.huskyrc
please move it to.config/husky/init.sh
Support for these will be removed in v10.
Friendly reminder
If Git hooks don't fit your workflow, you can disable Husky globally. Just add export HUSKY=0
to .config/husky/init.sh
.
I've seen some confusion about this on X, so just a heads-up!
Sponsoring
Husky is downloaded over 45M times per month and used by ~1.5M projects. If your company wants to sponsor, you can do so here: GitHub Sponsors.
Have a nice summer
v9.1.0
v9.0.11
- chore: update
package-lock.json
by @btea in https://github.com/typicode/husky/pull/1383 - fix:
export HUSKY=0
in init (fixes #1393) by @typicode in https://github.com/typicode/husky/pull/1395
v9.0.10
- fix: rename index.d.ts to index.d.mts by @mrkjdy in https://github.com/typicode/husky/pull/1379
v9.0.9
- refactor: rename files by @typicode in https://github.com/typicode/husky/pull/1378
v9.0.8
- docs: update index.md by @khaledYS in https://github.com/typicode/husky/pull/1369
- Fix tab detection on install command by @glensc in https://github.com/typicode/husky/pull/1376
- refactor: reduce file size by @typicode in https://github.com/typicode/husky/pull/1377
v9.0.7
- fix: typo and source
~/.huskyrc
correctly (compatibility with v8) - docs: fix example by @typicode in https://github.com/typicode/husky/pull/1363
v9.0.6
- docs: add favicon by @rakleed in https://github.com/typicode/husky/pull/1354
- chore: apply editorconfig to code only by @typicode in https://github.com/typicode/husky/pull/1355
- docs: update install script to mjs and fix CI checks by @starnayuta in https://github.com/typicode/husky/pull/1357
- Fix unbound variable by @typicode in https://github.com/typicode/husky/pull/1359
v9.0.5
- docs: update path to startup files by @ManuelRauber in https://github.com/typicode/husky/pull/1350
- fix: init error by @typicode in https://github.com/typicode/husky/pull/1353
v9.0.4
- fix: init create dir before by @typicode in https://github.com/typicode/husky/pull/1348
- refactor: simplify by @typicode in https://github.com/typicode/husky/pull/1349
- fix: init not working on pnpm #1334 by @rozbo in https://github.com/typicode/husky/pull/1347
v9.0.3
- docs: fix link by @typicode in https://github.com/typicode/husky/pull/1340
- chore: fix links in issue template by @julien-f in https://github.com/typicode/husky/pull/1341
- fix: add scripts field if not present by @chalkygames123 in https://github.com/typicode/husky/pull/1338
- docs: changelog link by @typicode in https://github.com/typicode/husky/pull/1343
- fix: insert final newline by @chalkygames123 in https://github.com/typicode/husky/pull/1339
- fix: fix git hooks path on windows by @rozbo in https://github.com/typicode/husky/pull/1346
v9.0.2
- fix: exit code by @gergelypap in https://github.com/typicode/husky/pull/1336
- docs: typo by @chalkygames123 in https://github.com/typicode/husky/pull/1337
v9.0.1
Kicking off the year with an exciting update!
Note: install using husky@latest
to get the bug fixes that were released after.
husky init
Introducing v8
npm pkg set scripts.prepare="husky install"
npm run prepare
npx husky add .husky/pre-commit "npm test"
v9
Adding husky to a project is now easier than ever. It's just a single line that does the same as above. No need to read the docs to get started anymore.
npx husky init
Adding a New Hook
v8
npx husky add .husky/pre-commit "npm test"
git add --chmod=+x .husky/pre-commit # On Windows
v9
Adding a hook is as simple as creating a file. This can be accomplished using your favorite editor, a script or a basic echo
command. For example, on Linux/macOS:
echo "npm test" > .husky/pre-commit
Further Size Reduction
v8
was already the most compact Git hooks manager at approximately 6kB
.
v9
takes this a step further, reducing the size to just 3kB
, likely making it the smallest devDependency in your toolkit.
To give you an idea of how small it is, the biggest file in the project is the MIT license
More to Come
Additional features are in the pipeline for v9
. Stay tuned
Other Changes
-
Enhanced security with CI and npm
--provenance
for safer publishing. - Added
$XDG_CONFIG_HOME
support. Move~/.huskyrc
to~/.config/husky/init.sh
for centralized configuration. - Fixed permission issue for Windows-created hooks; they no longer need to be executable.
- Removed
husky install
. Usehusky
orhusky some/dir
for the same functionality (deprecation notice to be added). - Modified behavior when
.git
is missing; it now triggers a warning instead of failure. - Replaced
HUSKY_DEBUG=1
withHUSKY=2
for debugging. - Updated the Husky API for module usage.
- Transitioned to
ESM
for module usage. - Dropped support for Node 14 and 16.
- Revamped docs.
How to Migrate
v9
is backward compatible with v8
, allowing you to freely upgrade and migrate your hooks later.
Here are the steps to migrate:
package.json
{
"scripts": {
- "prepare": "husky install"
+ "prepare": "husky"
}
}
.husky/pre-commit
- #!/usr/bin/env sh
- . "$(dirname -- "$0")/_/husky.sh"
npm test
Note: sh
will be used to run hooks, even if a shebang is set.
If you were using husky
as a module:
- const husky = require('husky')
- // ...
+ import husky from 'husky'
+ console.log(husky())
v8.0.3
- fix: add git not installed message #1208
v8.0.2
- docs: remove deprecated npm set-script
v8.0.1
- fix: use POSIX equality operator
v8.0.0
What's Changed
Feats
- feat: add
husky -
prefix to logged global error messages by @joshbalfour in https://github.com/typicode/husky/pull/1092 - feat: show
PATH
when command not found to improve debuggability - feat: drop Node 12 support
- feat: skip install if
$HUSKY=0
Fixes
- fix: hook script use
/usr/bin/env sh
instead of direct path ofsh
by @skhaz in https://github.com/typicode/husky/pull/1051 - fix: actually set 'husky_skip_init' as readonly in
./husky.sh
by @hyperupcall in https://github.com/typicode/husky/pull/1104 - fix: force
basename
/dirname
to treat$0
as an argument by @mataha in https://github.com/typicode/husky/pull/1132 - fix: remove
git.io
links by @renbaoshuo in https://github.com/typicode/husky/pull/1136
Docs
- docs: fix uninstall via npm by @pddpd in https://github.com/typicode/husky/pull/1033
- docs: add dog emoji as favicon by @jamiehaywood in https://github.com/typicode/husky/pull/1095
- docs: replace deprecated
npx --no-install
option withnpx --no
by @sibiraj-s in https://github.com/typicode/husky/pull/1070 - docs: add
pnpm
installation by @MohamadKh75 in https://github.com/typicode/husky/pull/1139
Chore
- chore: update workflows by @tiziodcaio in https://github.com/typicode/husky/pull/1125
v7.0.4
No changes. Husky v7.0.3 was reverted, this version is the same as v7.0.2.
v7.0.3
v7.0.2
Fix pre-commit hook in WebStorm (#1023)
v7.0.1
- Fix gracefully fail if Git command is not found #1003 (same as in v6)
v7.0.0
- Improve
.husky/
directory structure..husky/.gitignore
is now unnecessary and can be removed. - Improve error output (shorter)
- Update
husky-init
CLI - Update
husky-4-to-7
CLI - Drop Node 10 support
Please help me develop and release OSS projects
v6.0.0
After being in early access for Open Source projects and Sponsors for a limited time, I'm happy to announce that husky 6 is MIT again and can be freely used in commercial projects!
Many thanks to the Open Source projects and Companies which have switched to/sponsored the new husky during this period!
OSS is my full-time job, please consider sponsoring the development of husky on GitHub sponsors or Open Collective. Thank you!
Breaking change
-
husky init
has been moved to its own package (npx husky-init
)
Added
- Programmatically use husky:
require('husky')
- TypeScript definitions
Migrating from husky 4
Husky 6 contains breaking changes. If you're coming from v4, npm install husky@6
won't be enough.
Recommended: see husky-4-to-6 CLI to automatically migrate your config. There's also a dedicated section in the docs.
If you're curious why config has changed, you may be interested in reading: https://blog.typicode.com/husky-git-hooks-javascript-config/
Also Husky 6 follows official npm and Yarn best practices regarding autoinstall. It's recommended to use prepare
script instead (see usage in docs).
v5.2.0
- Add
set
command to replace hooks (husky set .husky/pre-commit cmd
) - Update
add
command to append command (husky add .husky/pre-commit cmd
) - Improve error messages
v5.1.3
- docs: add specific Yarn v2 install/uninstall instructions
- cli:
husky init
will detect Yarn v2 and initialize accordingly
v5.1.2
- docs: recommend
prepare
script instead ofpostinstall
(#890) - cli:
husky init
useprepare
script (#890)
v5.1.1
- style(shell): add trailing newlines (#870)
- fix(init): update package.json postinstall
v5.1.0
- Add
husky init
v5.0.9
- fix(install): do not fail if not inside a Git directory (closes #851)
See https://github.com/typicode/husky/releases/tag/v5.0.0 for v5 release notes
v5.0.8
v5.0.7
- fix(shell): double quote params (#824)
v5.0.6
- Remove unused files
v5.0.5
- Fix custom directory support #827
v5.0.4
v5.0.3
v5.0.2
v5.0.1
v5.0.0
Note about the license
Husky 5 is released under The Parity Public License.
It doesn't affect you if you're using husky in an Open Source project or if you're a sponsor. You're free to use it as usual and I hope you'll enjoy this new release
If you're using husky in a commercial project, you may want to consider becoming a sponsor to support the project. You can also try it for 30 days.
This is only for a limited time, husky will be MIT again later.
Migrating
Important Husky v5 brings a lot of improvements but is also very different from v4. Git hooks won't work if you only upgrade husky dependency, existing config needs to be migrated too.
The best way to switch to v5 is to follow the new installation instructions and migrate existing hooks command using husky add
.
Configuration
-
If you want to rebase/retry this MR, check this box
This MR has been generated by Renovate Bot.