If you don't care about writing good commit messages or just don't think that's important, it's probably because you had never spent a lot of time trying to find a commit using the git log command or related tools. You might think there's no reason to worry about it if you work alone, or if it's a personal project, but what happens when you work with a team or contribute to open-source projects, or simply needs to find an old commit?
To better highlight the importance of commit messages, below are a few points that describe few difficults when the messages are not well-written:
In general, good commit messages are important not only for others who may be collaborating on the project but also for you, to keep track of all commits and to be aware of what were the changes made so far in the project.
The commit message needs to be semantic, because these are categorized into meaningful types, indicating the essence of the commit., and it needs to be conventional because these are formatted by a consistent structure and well-known types for both developers and tools.
Most programming languages have well-established conventions, in this post, I'll address the Angular commit messages. But keep in mind that these principles can be applied to commit messages in any programming language.
The commit message should be structured as follow:
<type>[optional scope]: <description>
[optional body]
[optional footer]
It consists of three parts: header, body, and footer.
header: required line that simply describes the purpose of the change. It's composed by:
body: optional line that introduces the motivation behind the changes or just describing slightly more detailed information.
footer: optional line that mentions consequences that stems from the change, such as announcing a breaking change, linking closed issues, mentioning contributors and etc.
Below are some examples on how to use them:
feat(authentication): add support for OAuth2
This change adds support for OAuth2 authentication to the application. This allows users to log in using their Google, Facebook, or other OAuth2 provider accounts, in addition to the existing username/password login option.
See #456 for more details
chore: update dependency versions
This change updates the versions of several dependencies in the project. The updates include security and bug fix patches, as well as some performance improvements.
BREAKING CHANGE: this change introduces a breaking change to the API. Please see the documentation for more information.
The build type (formerly known as chore) is used to identify development changes related to the build system (involving scripts, configurations, or tools) and package dependencies. (ex: bump a dependency in package.json)
build: bump dependency versions in package.json
The ci type is used to identify development changes related to the continuous integration configuration files and scripts.
ci: update Travis CI configuration
The docs type is used to identify documentation changes related to the project. (ex: changes in README.md)
docs: update README with installation instructions
The feat type is used to identify production changes related to new backward-compatible abilities or functionality. (ex: add a new feature)
feat: add support for filtering search results
The fix type is used to identify production changes related to backward-compatible bug fixes. (ex: fix a bug)
fix: repair broken image links on user profile page
This change addresses an issue where the user profile page was displaying broken image links for some users. The issue was caused by a bug in the code that was generating the links, which has now been repaired.
Closes #234
The perf type is used to identify production changes related to backward-compatible performance improvements. (ex: code change that improves performances)
perf: optimize SQL query for customer data analysis
This change optimizes the SQL query used for customer data analysis by adding indexes to the relevant tables and reworking the query structure to take advantage of these indexes. The optimization reduces the runtime of the query by approximately 50%, allowing for faster analysis of customer data.
The refactor type is used to identify development changes related to modifying the codebase, which neither adds a feature nor fixes a bug. (ex: removing redundant code, simplifying the code, renaming variables, etc.)
refactor: improve error handling in API route
The style type is used to identify development changes related to styling the codebase, regardless of the meaning. (ex: indentations, semi-colons, quotes, trailing commas, etc.)
style: update naming conventions for database tables
The test type is used to identify development changes related to tests. (ex: adding missing tests or correcting existing tests)
test: add integration tests for data pipeline
This change adds integration tests for the data pipeline to ensure that data is being correctly extracted, transformed, and loaded into the target database. The tests cover a variety of scenarios, including handling of invalid input data, edge cases, and performance testing.
Nowadays companies tend to use task management tools (such as Jira, TFS/Azure DevOps) to keep track of the work. Usually, the task is described in tickets containing all the clarifications about the requirements. Each ticket will have a unique ID that can be used in our commit messages. Let's say you were assigned to a ticket with an ID of CORGI-109, when the time to commit your changes comes, use that ID as the scope of your message, for example:
CORGI-109: add support for importing data from CSV files
CORGI-109: optimize ETL pipeline for large data sets
CORGI-109: fix bug in data cleansing script
CORGI-109: refactor data storage layer to use NoSQL database
CORGI-109: add unit tests for data validation routines
CORGI-109: optimize database query for improved performance
This will help you and your team to keep track of the publishes that are happening in the version control system.
Last but not least, you can also use emojis in commit messages to improve readability and quickly understand the purpose of a commit. Using emojis can also help to standardize commit messages within a team or project. For choosing the right emoji, Gitmoji is a helpful resource that provides a guide specifically for commit messages with emojis.
Conventional commits offer several benefits, including:
To summarize, improving your commit messages will not help only you but also other developers who will be working on the project. In general, it will make you a better collaborator.