commitizen
commitizen copied to clipboard
Option to allow `fixup!` and `squash!` in commit messages
Description
It would be nice if cz check
didn't fail for fixup and squash commits, e.g., git commit --fixup <rev>
or git commit --squash <rev>
if the commit messages are otherwise acceptable. In git worflows that use rebase and --autosquash
, the offending commit message portion (squash!
or fixup!
) will be removed. This is especially annoying when commitizen is used with pre-commit
, because every time you do a squash or fixup commit you have to SKIP=commitizen git commit --fixup ...
.
Possible Solution
Add a CLI option to cz check
for this such as --autosquash
or some better name which, if true, prepends the commit message check regex pattern with something like r"((fixup|squash)\!\s)?"
I haven't thought through all of the use cases, but a CLI option may be preferable to a config setting in e.g., toml because you may want the behavior to be different when you are committing (allow) versus pushing or in your CI pipeline (deny). So having something that can be changed a bit more easily than a config option may be desirable. But I hold this opinion lightly.
I'm good with this feature @Woile What do you think?
I'm fine with it, just wondering how to include this. We also have the signed commits with -s
, I was wondering if we should move forward with
cz check -- {extra parameters propagated to git}
cz commit -- {extra parameters propagated to git}
What do you think would be the best interface?
I'm ok with -- {extra parameters propagated to git}
. Implement each git argument would be a huge burden for us
I don't think this is related to git itself. It's just a matter of allowing fixup commits in the regexp.
For example, having the commit-msg pre-commit hook installed, there should be a way to let this not fail:
> git commit -a --fixup 57a2044f1290cba0ca6530e6e77cd5da243e74b1
commitizen check.........................................................Failed
- hook id: commitizen
- exit code: 14
commit validation: failed!
please enter a commit message in the commitizen format.
commit "": "fixup! feat: allow easy working"
pattern: (build|ci|docs|feat|fix|perf|refactor|style|test|chore|revert|bump)(\(\S+\))?!?:(\s.*)
if that's the case, I'm ok with it. @Woile what do you think?
fine by me as well :+1:
Hey guys, found that issue and as workaround I started using a custom schema_pattern
today, so far it behave as expected, even though I would also prefer to see it directly as feature (maybe I find some time to checkout the code base and create a pull request), is that a doable alternative in your opinion or do I miss an important part here?
commitizen:
name: cz_customize
customize:
schema_pattern: ((fixup|squash)\!\s)?(|build|ci|docs|feat|fix|perf|refactor|style|test|chore|revert|bump)(\(\S+\))?!?:(\s.*)
Thanks @wombelix I think it's a great workaround