Add Conventional Commit tooling
See original GitHub issueContext
Currently, we have guidelines for how to format commit message in general, but do not have enforced standards for how to add commit metadata (is this a breaking change, is this a bugfix, other changes adjacent to semantic versioning concerns, etc.) We stopgap some of that with Github labels, but those do not exist in the Git commit history.
Proposal
- enforce the Conventional Commit format for all commits that are merged to the main branch
- this will allow us to automatically determine the appropriate semantic version for post-1.0 releases of Excalibur
 
- add optional linting command for developers to use locally
- this prevents having to require that community contributors follow the strict commit message format, since we squash and rebase all pull requests when merging
 
- automate changelog updates on pull request merge
- if commit messages are required to be well-formatted and provide proper context, then the vast majority of the changelog can be automated
 
- maintain the majority of our git commit message format conventions, as described in our Contributing document
- update the Contributing document to include the new Conventional Commits formatting guidelines
Commit Format Examples
General template:
<type>[optional scope]: <Description>
[optional body]
closes #issue_number
Specific example:
fix: Prevent sounds from playing when the game is stopped
Ensure all sounds stop when the game is stopped, and Sound.play() does not play sounds when the game is stopped
closes #1476 
additional info: https://www.conventionalcommits.org
See also https://github.com/excaliburjs/Excalibur/issues/777
Issue Analytics
- State:
- Created 3 years ago
- Reactions:2
- Comments:6 (3 by maintainers)
 Top Results From Across the Web
Top Results From Across the Web
Tooling for Conventional Commits
go-conventional-commits: A tool to parser your git commit messages into a change log message based on conventional commits specification.
Read more >Convco | Conventional commit tools
A Conventional commit cli build with Rust. convco gives tools to work with Conventional Commits. The tool is still in early development, but...
Read more >Conventional Commits: A Better Way | Neudesic Innovation
The concept behind Conventional Commits is to provide a rich commit history that can be read and understood by both humans and automated...
Read more >Conventional Commit Messages - gists · GitHub
#!/usr/bin/env sh commit_message="$1" # exit with a non zero exit code incase of an invalid commit message # use git-conventional-commits, see https://github.
Read more >Apply conventional commit style on your project with commitlint
After performing some code changes (editing files, adding a new file, and deleting files), we must commit to adding our change in Git ......
Read more > Top Related Medium Post
Top Related Medium Post
No results found
 Top Related StackOverflow Question
Top Related StackOverflow Question
No results found
 Troubleshoot Live Code
Troubleshoot Live Code
Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start Free Top Related Reddit Thread
Top Related Reddit Thread
No results found
 Top Related Hackernoon Post
Top Related Hackernoon Post
No results found
 Top Related Tweet
Top Related Tweet
No results found
 Top Related Dev.to Post
Top Related Dev.to Post
No results found
 Top Related Hashnode Post
Top Related Hashnode Post
No results found

Perhaps worth mentioning an alternative for those who don’t want the chore of enforcing and abiding by conventional commit standards. Beachball JS was developed and is used extensively throughout Microsoft. It’s an alternative to Conventional Commits that solves the same problems in a more streamlined way without relying on commit messages. Only mentioning it because our projects recently shifted over, and we found it reduced a lot of friction and need for compliance verification. I think this ticks all the checkboxes described in the issue.
https://microsoft.github.io/beachball/
When a dev commits a change, they must create a
changefile. This is done automatically for you by executingbeachball change. This initiates a quick series of questions – it automatically determines which packages were modified (in the case of a monorepo) and asks what kind of change was made (patch, minor, major, etc) with a clear definition of each change to help new contributors. Finally you add a quick description of the change, or can select from the last few commit messages. This generates achangejson file, which is checked in automatically.A post-push git hook can validate that change files were generated using the
beachball checkcommand. If not the push can be denied and a descriptive error shown to guide new contributors. This can also be done during CI to be sure all commits are mapped to a change file before merging into the master branch.During the CD pipeline, the
beachball publishcommand initiates a review of all change files. Based on the changes and their types, it chooses the proper semver value, and updates the packages and auto-generates new changelog histories. These are committed back to the branch automatically, and the change files themselves are deleted. The publish command automatically initiates annpm publishof any packages that were modified.This issue hasn’t had any recent activity lately and is being marked as stale automatically.