Skip to content
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

fix: commitlint --last fails #3981

Closed
1 of 4 tasks
mfcollins3 opened this issue Mar 16, 2024 · 11 comments · Fixed by #3982
Closed
1 of 4 tasks

fix: commitlint --last fails #3981

mfcollins3 opened this issue Mar 16, 2024 · 11 comments · Fixed by #3982
Labels

Comments

@mfcollins3
Copy link

mfcollins3 commented Mar 16, 2024

Steps to Reproduce

I created a valid commit message and used the npx commitlint --last --verbose command to validate the commit message as shown here. I received the following errors:

  • subject may not be empty [subject-empty]
  • type may not be empty [type-empty]

The commit message was:

ci: validate commit messages

I added development dependencies on commitlint and husky. commitlint is
being used to validate commit messages conform to the Conventional
Commits format and follow the configured rules for the project. husky is
being used to run commitlint on every commit using the commit_msg Git
hook.

I created the setup.sh script to automate the steps to install the
project dependencies after cloning the repository.

I updated README.md with instructions on cloning the repository and
running the setup.sh script. I created the software requirements
document to list the software that developers need to install in their
development environments in order to contribute to the product.

I created CONTRIBUTING.md with instructions on how to contribute to the
product. I added instructions on commit signing,
writing commit messages, and the workflows for bug fixes or implementing
new features.

I created the commitlint GitHub Actions workflow to run commitlint to
validate commit messages for the main branch or pull requests for the
main branch.

My configuration is:

export default {
    extends: ['@commitlint/config-conventional'],
    rules: {
        'body-max-line-length': [1, 'always', 72],
        'body-case': [1, 'always', 'sentence-case'],
        'footer-max-line-length': [1, 'always', 72],
        'header-max-length': [2, 'always', 52],
        'scope-enum': [2, 'always', [
            'android',
            'api',
            'flutter',
            'ios'
        ]],
        'type-enum': [2, 'always', [
            'build',
            'change',
            'chore',
            'ci',
            'deprecate',
            'docs',
            'feat',
            'fix',
            'perf',
            'refactor',
            'remove',
            'revert',
            'security',
            'style',
            'test'
        ]]
    }
};

Running npx commitlint --from HEAD~1 --to HEAD --verbose succeeds.



### Current Behavior

```sh
✖   subject may not be empty [subject-empty]
✖   type may not be empty [type-empty]

✖   found 2 problems, 0 warnings

Expected Behavior

Commitlint should succeed and validate that the commit message is valid.

Affected packages

  • cli
  • core
  • prompt
  • config-angular

Possible Solution

No response

Context

No response

commitlint --version

@commitlint/cli@19.2.0

git --version

2.44.0

node --version

20.11.1

@mfcollins3 mfcollins3 added the bug label Mar 16, 2024
@escapedcat
Copy link
Member

/cc @knocte

@knocte
Copy link
Contributor

knocte commented Mar 16, 2024

@mfcollins3 thanks for reporting this bug, we'll look at it on Monday.

webwarrior-ws added a commit to webwarrior-ws/commitlint that referenced this issue Mar 18, 2024
…est for running with --last flag. See [1].

Added regression test for running with --last flag. See [1].

[1] conventional-changelog#3981
webwarrior-ws added a commit to webwarrior-ws/commitlint that referenced this issue Mar 18, 2024
Added regression test for running with --last flag. See [1].

[1] conventional-changelog#3981
webwarrior-ws added a commit to webwarrior-ws/commitlint that referenced this issue Mar 18, 2024
Added regression test for running with --last flag. See [1].

[1] conventional-changelog#3981
webwarrior-ws added a commit to webwarrior-ws/commitlint that referenced this issue Mar 18, 2024
Added regression test for running with --last flag. See [1].

[1] conventional-changelog#3981
webwarrior-ws added a commit to webwarrior-ws/commitlint that referenced this issue Mar 18, 2024
Fixed regression [1] when using --last flag.

[1] conventional-changelog#3981
webwarrior-ws added a commit to webwarrior-ws/commitlint that referenced this issue Mar 18, 2024
Fixed regression [1] when using --last flag.

[1] conventional-changelog#3981
webwarrior-ws added a commit to webwarrior-ws/commitlint that referenced this issue Mar 18, 2024
escapedcat pushed a commit that referenced this issue Mar 19, 2024
* test(cli): add regression test for --last flag

Added regression test for running with --last flag. See [1].

[1] #3981

* fix(cli): fixed regression when using --last flag

Fixed regression when using --last flag.

Fixes #3981
@schimini
Copy link

schimini commented Oct 9, 2024

This might still be happening:

npx commitlint --last                               
⧗   input: "fix: f around

test
"
✖   subject may not be empty [subject-empty]
✖   type may not be empty [type-empty]

✖   found 2 problems, 0 warnings
ⓘ   Get help: https://github.com/conventional-changelog/commitlint/#what-is-commitlint

npx commitlint --from HEAD~1 --to HEAD --verbose
⧗   input: fix: f around
✔   found 0 problems, 0 warnings

@knocte
Copy link
Contributor

knocte commented Oct 9, 2024

@schimini can you give us access to that repo? can we fork it or...?

@schimini
Copy link

@knocte yes check here: https://github.com/schimini/strapi

happened basically with all my commits.
but running with the from and to flags it worked properly

@webwarrior-ws
Copy link
Contributor

@schimini
I can't run commitlint against your repo at all.
I get an error:

file:///home/ubuntu/.npm/_npx/16d437951fea4b5e/node_modules/@commitlint/cli/lib/cli.js:132
        throw err;
        ^

Error: Cannot find module '@commitlint/types'

If I try to install @commitlint/types, I get this:

npm ERR! code EUNSUPPORTEDPROTOCOL
npm ERR! Unsupported URL Type "workspace:": workspace:*

Node.js v18.19.1
npm v10.2.4
Ubuntu 22.04

@schimini
Copy link

Hmm that's weird :o
What the version you have for the cached commitliint?

my setup is:

node --version
v18.19.0
strapi % npm --version
10.2.3
strapi % npx commitlint --version 
@commitlint/cli@19.2.0

@webwarrior-ws
Copy link
Contributor

@schimini

npx commitlint --version 
@commitlint/cli@19.5.0

@schimini
Copy link

@webwarrior-ws I am clueless

I tried the latest even and it ran with no problems

strapi % npx commitlint@latest --from HEAD~1 --to HEAD --verbose                          
Need to install the following packages:
commitlint@19.5.0
Ok to proceed? (y) y
⧗   input: chore: run prettier write on clean schema attributes
✔   found 0 problems, 0 warnings

@webwarrior-ws
Copy link
Contributor

@schimini
Does --last work with the latest version?

@schimini
Copy link

@webwarrior-ws ha ha!
It does. Disregard my comments! Sorry to waste your time.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Development

Successfully merging a pull request may close this issue.

5 participants