DEV Community

Cover image for “Good Commit” vs “Your Commit”: How to Write a Perfect Git Commit Message
Safdar Ali
Safdar Ali

Posted on

“Good Commit” vs “Your Commit”: How to Write a Perfect Git Commit Message

"A good commit shows whether a developer is a good collaborator." — Peter Hutterer, Linux.

Years ago, I never realized there were specific rules for writing commit messages until my curiosity got the best of me. I used to think that straightforward messages like “added feature 2,” “fixed the bug on the Main Navigation bar,” or even “foo” were sufficient. The conviction that commit messages went largely unread proved mistaken. In reality, well-crafted commit messages are indispensable, ensuring that our future selves benefit from our diligence and thoughtfulness.

Why You Should Care About Writing Clean Commit Messages

Commits serve as the tangible building blocks of a programmer’s craft. They act as the icing on the cake of code, and when written correctly, they bring substantial value. A well-written commit message becomes indispensable because they provide context — otherwise, a commit message wouldn’t be needed in the first place.

"A good commit shows whether a developer is a good collaborator." — Peter Hutterer, Linux.

Common Mistakes in Commit Messages

Before diving into the rules, let’s address some common mistakes developers often make:

1. Vague Messages

  • Example: “Fixed it”
  • Why it’s bad: This provides no context on what was fixed or where.

2. Too Much Information

  • Example: “Refactored the entire application, fixed all bugs, added new features, updated documentation.”
  • Why it’s bad: This makes it difficult to pinpoint what exactly was done.

3. Irrelevant Details

  • Example: “Had coffee, then fixed bug #1234”
  • Why it’s bad: Personal anecdotes don’t belong in commit messages.

The 7 Rules for Writing Perfect Commit Messages

  1. Keep It Short and Sweet
  • Limit the subject line to 50 characters or less.
  • Example: “Add user authentication”
  1. Use the Imperative Mood
  • Think of your commit message as a command.
  • Example: “Fix login bug” instead of “Fixed login bug” or “Fixes login bug”
  1. Separate Subject from Body with a Blank Line
  • Helps in readability and clarity.
  • Example:
Add user authentication

Implemented JWT for secure authentication.
Updated user model to include password hashing.
Enter fullscreen mode Exit fullscreen mode
  1. Capitalize the Subject Line
  • Example: “Update README with installation instructions”
  1. Do Not End the Subject Line with a Period
  • Example: “Improve performance of data fetching”
  1. Use the Body to Explain What and Why, Not How
  • Example:
Refactor user service

Split the user service into smaller, more manageable functions.
This will help in maintaining and testing the code more efficiently.
Enter fullscreen mode Exit fullscreen mode
  1. Be Consistent
  • Maintain a consistent style across all commit messages.

Case Study: From Bad to Good

Bad Commit Message:

Fixed issue #456
Enter fullscreen mode Exit fullscreen mode

Improved Commit Message:

Resolve issue #456: Fix null pointer exception in UserService

The null pointer exception was occurring due to an uninitialized object.
Added a check to initialize the object before accessing its properties.
Enter fullscreen mode Exit fullscreen mode

Tips for Writing Better Commit Messages

  1. Think Before You Type
  • Reflect on what you’ve done and why it matters.
  1. Use Tools and Templates
  • Utilize commit message templates to ensure consistency.

  • Example template:

Subject: [TASK] - Description

Body: 
- What was done
- Why it was done
- Any additional notes
Enter fullscreen mode Exit fullscreen mode
  1. Review Before Committing
  • Always read your commit message before finalizing it.
  1. Collaborate with Your Team
  • Discuss and agree on a commit message convention with your team.

Conclusion

Writing good commit messages is an art that every developer should master. They are not just a formality but a crucial part of the development process that aids in understanding the history and evolution of a project. By following these guidelines, you can ensure that your commit messages are clear, concise, and valuable to your team.

By adopting these practices, you’ll not only improve your own workflow but also enhance collaboration and productivity within your team. Remember, a good commit message is the hallmark of a diligent and thoughtful developer. So, next time you’re about to commit, take a moment to craft the perfect message.

That's all for today.

And also, share your favourite web dev resources to help the beginners here!

Connect with me:@ LinkedIn and checkout my Portfolio.

Explore my YouTube Channel! If you find it useful.

Please give my GitHub Projects a star ⭐️

Thanks for 23428! 🤗

Top comments (38)

Collapse
 
gopikrishna19 profile image
Gopikrishna Sathyamurthy

Great article!! If you are interested in further improving your commit messages, take a look at conventional-commits. It can help you write commit messages in a semantic manner and help in automating a couple of things like release management and changelog generation.

conventionalcommits.org/en/v1.0.0/
github.com/semantic-release/semant...

🚀 🚀 🚀

Collapse
 
wolfsrudel profile image
Wolfsrudel

This is the most valuable comment. 👍🏼

Collapse
 
safdarali profile image
Safdar Ali

Do Subscribe my YouTube Channel!!! If you all find it helpful as subscription is free but it will motivate me to be active here :)

Collapse
 
thomas_menzel_ff6c1ba46fa profile image
thomas menzel

While I largely agree on Ur points I'm missing why certain things matter, e.g. why the imperative style on commits? I personally prefer the "adds foo ..." Form. Reason: b/c it describes one of many logical step on a topic (branch) which has a goal, that I express then in the imperative, eg "fix bug 2345 scratch that itch"

Collapse
 
gopikrishna19 profile image
Gopikrishna Sathyamurthy

It is to read like "when you apply this commit it will 'fix bug 2345'". Now if you have any other tense or tone, it'd be weird.

This is a good copy paste reminder of this article from 2014: cbea.ms/git-commit/

Collapse
 
tacodes profile image
tacodes

Wow it sure is. Sigh

Thread Thread
 
safdarali profile image
Safdar Ali

Do Subscribe my YouTube Channel!!! If you all find it helpful as subscription is free but it will motivate me to be active here :)

Collapse
 
will_fry_ef812623244eb56a profile image
Will Fry

I mean you could make the exact same argument for "when you apply this commit it 'fixes bug 2345'".

Collapse
 
moopet profile image
Ben Sinclair

What does 23428 signify?

Collapse
 
safdarali profile image
Safdar Ali • Edited

It signifies no. of ❤️ I got till date .Do Subscribe my YouTube Channel!!! If you all find it helpful as subscription is free but it will motivate me to be active here :)

Collapse
 
muhammadanas8 profile image
MuhammadAnas8

Thanks for sharing

Collapse
 
safdarali profile image
Safdar Ali

Do Subscribe my YouTube Channel!!! If you all find it helpful as subscription is free but it will motivate me to be active here :)

Collapse
 
safdarali profile image
Safdar Ali

You're Welcome :)

Collapse
 
mateush profile image
Matéush

I read your article - you can find it on my YouTube channel. I should look into conventional commits.

youtu.be/tnLhwl9hC_A

Collapse
 
safdarali profile image
Safdar Ali

Do Subscribe my YouTube Channel!!! If you all find it helpful as subscription is free but it will motivate me to be active here :)

Collapse
 
mateush profile image
Matéush

No thank you, I have no interest in React nor JS.

Collapse
 
darkwiiplayer profile image
𒎏Wii 🏳️‍⚧️

Personal anecdotes don’t belong in commit messages

Not in the title line, at least. If you want to be funny in the body of the commit message, unless you're wasting the reader's time, that's not really a problem.

Resolve issue #456: Fix null pointer exception in UserService

Personally, I find it distracting to add platform-specific information to your status line. In git terms, #456 means absolutely nothing. Most devs will know that it's some sort of issue number, but that doesn't really help at all when reading the log.

Normally, what you want to see at a glance is: What does this commit do. If you're curious why it does that, you'll read the full commit message anyway. And at that point, it's better to have a full link to the issue so it can be accessed without knowing what issue tracker is being used for the project.

Ideally, you put the explanation of the issue in the commit message; you never know when microsoft might decide to make the issue tracker a premium feature if they're feeling entitled to more of people's hard-earned money.

Overall, I think the subject line should tell you nothing more than what a commit does in a very concise way. Maaaaaybe a short tag like [fix] or [feat] can be added too for a bit more context, but other than that, the primary rule of thumb is: "Concise status line, have fun with the body".

Collapse
 
ingosteinke profile image
Ingo Steinke, web developer

Mentioning issue numbers in commit messages can be very helpful in short-term mid-term, especially in a setup where this will be displayed as a link to an issue or serve as a hint to automatically close the linked issue as resolved.

Collapse
 
darkwiiplayer profile image
𒎏Wii 🏳️‍⚧️

Yea, but they should ideally only complement a proper description of why a change was necessary, rather than defer entirely to some external system that may or may not be there anymore when someone reads the commit in 5 years.

It also serves that purpose perfectly well in the body of the commit message, so there's no reason to put it in the title line, where people want a concise summary, not a link they first have to click.

Collapse
 
thaisavieira profile image
Thaísa Vieira

That is one of the best guides about writing commits I've read. It's so clear and with simple examples, ideal even for begginers like me!

Collapse
 
safdarali profile image
Safdar Ali • Edited

Glad to hear that ❤️ @Thaísa Vieira. Let's connect here linkedin.com/in/safdarali25. Can checkout, here I share awesome stuffs on web and for web ✨.

Collapse
 
valeriahhdez profile image
Valeria writes docs

Hey, finally I get instructions on writing good commit messages that goes beyond the "be clear and concise". Thanks!

Collapse
 
safdarali profile image
Safdar Ali

Do Subscribe my YouTube Channel!!! If you all find it helpful as subscription is free but it will motivate me to be active here :)

Collapse
 
martinbaun profile image
Martin Baun • Edited

Thanks for the insightful perspective. Commit messages are very crucial!

Collapse
 
safdarali profile image
Safdar Ali

Do Subscribe my YouTube Channel!!! If you all find it helpful as subscription is free but it will motivate me to be active here :)

Collapse
 
safdarali profile image
Safdar Ali

Thanks for 23428! 🤗

Collapse
 
abdurrahmanador profile image
Abdur Rahman

*JajhakAllohu Khoir , Brother. *

Collapse
 
safdarali profile image
Safdar Ali

Do Subscribe my YouTube Channel!!! If you all find it helpful as subscription is free but it will motivate me to be active here :)

Collapse
 
febin_k profile image
Febin

Thanks for the insights :)

Collapse
 
safdarali profile image
Safdar Ali

Do Subscribe my YouTube Channel!!! If you all find it helpful as subscription is free but it will motivate me to be active here :)

Collapse
 
orphe_16e1891502 profile image
Orphée Djahoui

🤖🎉🎉

Collapse
 
safdarali profile image
Safdar Ali

Do Subscribe my YouTube Channel!!! If you all find it helpful as subscription is free but it will motivate me to be active here :)

Collapse
 
malakutsko profile image
Victoria • Edited

Our application is large, it has a lot of features. When I write a commit message, I often feel like I should specify, which feature this change belongs to. For example, the commit sounds like Refactor foo_method in Scope::Services::BarProvider (random slightly complicated thing), but from this message it's not clear, what part of application has been affected. I then want to write something like Messenger: refactor foo_method in Scope::Services::BarProvider. The more correct way would be Refactor foo_method in Scope::Services::BarProvider in Messenger, but it sounds a bit silly. It's probably not a good example, because here the Scope might give an idea about the feature or module, but imagine that it wouldn't.

What do you folks do in such situations?

Collapse
 
rahulvijayvergiya profile image
Rahul Vijayvergiya

Thanks for the article, but i think you should also include ** conventional commit ** thats a industry standard, which helps to make good release notes out of it.
dev.to/rahulvijayvergiya/git-conve...

Some comments may only be visible to logged-in visitors. Sign in to view all comments.