commitizen icon indicating copy to clipboard operation
commitizen copied to clipboard

Option to allow `fixup!` and `squash!` in commit messages

Open lobotmcj opened this issue 3 years ago • 8 comments

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.

lobotmcj avatar Aug 21 '21 14:08 lobotmcj

I'm good with this feature @Woile What do you think?

Lee-W avatar Aug 25 '21 10:08 Lee-W

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?

woile avatar Aug 25 '21 17:08 woile

I'm ok with -- {extra parameters propagated to git}. Implement each git argument would be a huge burden for us

Lee-W avatar Aug 26 '21 00:08 Lee-W

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

yajo avatar Mar 28 '22 08:03 yajo

if that's the case, I'm ok with it. @Woile what do you think?

Lee-W avatar Mar 29 '22 01:03 Lee-W

fine by me as well :+1:

woile avatar Mar 29 '22 10:03 woile

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

wombelix avatar May 16 '22 17:05 wombelix

Thanks @wombelix I think it's a great workaround

Lee-W avatar May 22 '22 10:05 Lee-W