-
-
Notifications
You must be signed in to change notification settings - Fork 430
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Feature: Option to skip hooks #1127
Conversation
That is not complete, the following commands also call hooks:
Besides, can we merge the two options |
bbee0bc
to
d830175
Compare
I'll add the option to those extra commands and I think documentation needs an update on this (they are not listen) or at least an explanation that signals does not match the commands but the actions executed by commands (if I understand well, install can trigger For the
|
A Lifecycle documentation would be superb!
Yeah, I love the shortcuts |
970a4e3
to
d3e8337
Compare
Codecov ReportAttention: Patch coverage is
Additional details and impacted files@@ Coverage Diff @@
## dev #1127 +/- ##
==========================================
+ Coverage 84.36% 84.58% +0.21%
==========================================
Files 79 80 +1
Lines 6958 7030 +72
Branches 1652 1663 +11
==========================================
+ Hits 5870 5946 +76
+ Misses 733 731 -2
+ Partials 355 353 -2
Flags with carried forward coverage won't be shown. Click here to find out more. ☔ View full report in Codecov by Sentry. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@noirbizarre Thanks for your work on that feature. The code is of high quality and your Python skills are awesome. I've made some comments and improvement suggestions. Also, would you like to write a new documentation page about hooks?
@frostming I've been meaning to add a bug for a while that it seems like the relevant hooks aren't called from pdm-pep517 (e.g. if you add a pre_build hook it doesn't get called from python -m build). If hooks are a fundamental part of PDM (and not just a part of the CLI) would it make sense to move HookManager into pdm-pep517 and then import it here? |
I have a different opinion on that. Lifecycle scripts should be considered part of the package manager PDM, i.e. the frontend, rather than pdm-pep517, the backend. Like in node.js world, Yarn and npm support different lifecycle scripts. If you use other frontends like build, they may not call the hooks. Besides, pdm-pep517, as a backend, only participates in the build process, it has nothing to do with install/lock/init. |
f1c9569
to
0dc1ed8
Compare
👆🏼 Thanks 🙏🏼 🙏🏼 I applied changes/suggestions and rebased on the latest Another question: do you me to add a |
Thanks, hope my updates to the dev branch don't cause too much trouble. The CI seems passing.
A separate PR would be okay.
Sure, go ahead for it. |
As soon as I understood
OK, let's go this way 👍🏼
Great, I'll add them in another PR too So the PR should be good to merge and I'll submit extra changes ( (And thanks for the reactivity, it's a pleasure contributing with quick feedback) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
Great 🎊 |
* feat(core): Use tomllib on Python 3.11 (#1072) * docs: 📝 Fix typo in `pip install pdm` description (#1061) * Use tomllib on Python 3.11 * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * news * use a compatibility module * missed one import Co-authored-by: t106362512 <[email protected]> Co-authored-by: hauntsaninja <> Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> * feat(core): Replace halo, click, and termcolor with rich (#1091) * feat(core): Use `unearth` as the backend to find and download packages (#1096) * perf(resolver): Speed up the resolution with lazy find_matches (#1098) * Improve the output of installing packages * Use confirm instead of ask * feat(core): New command: pdm publish (#1107) * Use rich handler for logging to stderr * feat(scripts): added composite tasks support (#1117) * feat(core): Add option to skip hooks (#1127) * fix(scripts): allow pdm test command to receive path arguments * feat(hooks): added a `--skip` option to skipp scripts and hooks (#1127) fix #948 * feat(hooks): use PDM_SKIP_HOOKS environement variable as fallback for skip list * feat(core): Support setup.py import (#1137) * Update completion script * fix(resolution): fix a bug that versions with local part can't be found and installed Close #1093 * feat(core): forbid editable depenencies in project table (#1140) * Make the error message more friendly * doc: improve the docs about dependencies * doc: add CLI reference doc * doc: use asciiart as the program description * chore: remove remaining artifacts from #1127 (#1152) * Feature: complete lifecycle signals and documentation (#1147) * feat(hooks): Added pre-publish hook * refactor(hooks): dynamic signal/hooks listing avoiding double declaration * feat(hooks): added (pre|post)_script and (pre|post)_run hooks * doc(hooks): added lifecycle and hooks documentation * review fix * fix(tests): add and use the _echo fixture for cross-plateform and concise test echos * refactor(hooks): automatically register the script handler for all hooks * feat: Update pdm-pep517 to 1.0 (#1153) * fix(scripts): merge the Script and Description field from listing (#1151) * feat: fetch the candidate hashes concurrently (#1154) * feat: fetch the candidate hashes concurrently * add news * Feat/respect-source-order (#1155) * doc: restructure the docs about project metadata and build configuration * parse pep 621 metadata to avoid build (#1156) * feat: Remove the compatible support for pdm legacy metadata (#1157) * fix(config): use platform standard directories for all PDM directories (#1161) Fixes #1150 * fix(#1156): only trust parsing result when all are static * New build configuration table * chore: added a tox.ini file for easier local testing against all Python versions (#1160) * feat(CLI): Yarn-like root scripts fallback (#1159) * feat(hooks): added a post_use hook (#1163) Co-authored-by: Shantanu <[email protected]> Co-authored-by: t106362512 <[email protected]> Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com> Co-authored-by: Axel H <[email protected]>
Pull Request Check List
news/
describing what is new.Describe what you have changed in this PR.
This PR is a proposal at implementing #948.
If provides 2 parameters:
--skip-hooks
that will skip any hook (or pre/post script) involved in the execution--skip
which can take any arbitrary task or hook name(s) and skip it/themThose 2 parameters have been added to the following commands
run
install
lock
build
init
The
--skip
can be used many times. The following commands are all equivalents--skip=pre_task1,task2
--skip pre_task1,task2
--skip=pre_task1 --skip=task2
--skip pre_task1 --skip task2
The both options can be used together:
pdm run --skip-hooks --skip=taskn my-composite-task