Skip to main content

How to Write Good Commit Messages: Best Practices for Teams

Photo by Yancy Min on Unsplash


Git commit messages are essential for maintaining a clear and collaborative history of a project. Poorly written commit messages can lead to confusion, making it hard to understand the intent behind changes. In this guide we will run through practical best practices for writing meaningful commit messages and promoting uniformity in teams.

Why Good Commit Messages Matter

  1. Clarity: A clear commit message explains what changes were made and why.
  2. Collaboration: With multiple developers, standardized messages improve team understanding.
  3. Debugging: Helpful messages make it easier to trace bugs to specific changes.

The 50/72 Rule

A typical commit message has two main parts:

  1. Subject line: A concise summary of the change (max 50 characters).
  2. Body (optional): Detailed description of what and why (wrapped at 72 characters).

Example:

Commit Message Best Practices

1. Use the Imperative Mood: Start with a verb as if giving a command.

  • Good: fix: resolve null pointer exception
  • Bad: fixed the null pointer exception

2. Be Concise: Summarize the change in 50 characters or fewer.

3. Provide Context: Explain why the change was necessary in the body.

4. Use a Prefix for Type: Adopt a conventional format like type: message.

  • Common prefixes:
  • feat: New feature
  • fix: Bug fix
  • chore: Miscellaneous changes
  • refactor: Code improvement without feature/bug changes
  • test: Adding or updating tests
  • docs: Documentation updates

5. Separate Concerns: Commit one logical change at a time.

  • Avoid: fix auth and update UI
  • Use: fix: resolve auth issue and style: update login page UI

6. Capitalize the First Word: Always start with a capital letter.

7. Avoid Periods in the Subject Line: Periods are redundant in short messages.

Practical Guidelines for Team Standardization

1. Adopt a Commit Convention:

  • Example:

2. Use Pre-Commit Hooks:

  • Enforce rules using Git hooks or tools like Husky.

3. Code Reviews for Commit Messages:

  • Ensure meaningful messages during pull requests.

4. Document the Guidelines:

  • Include commit message standards in the team’s README or CONTRIBUTING.md file.

5. Automate Checks:

  • Use tools like Commitlint to validate commit messages.

Sample CLI Commands for Writing Commit Messages

Here are some examples of how to craft commit messages using Git CLI while following best practices:

1. Simple Commit:

2. Commit with Body:

3. Commit with Scope:

4. Amending a Commit:

5. Interactive Add and Commit:

6. Commit Multiple Changes:

  • Split changes into logical commits:

Conclusion

Well-written commit messages are vital for project clarity and collaboration. By following best practices and enforcing team-wide standards, you can create a more efficient development workflow. Remember, a clean commit history is not just documentation — it’s a reflection of a well-organized project.

Comments

Popular posts from this blog

Understanding Number Systems: Decimal, Binary, and Hexadecimal

In everyday life, we use numbers all the time, whether for counting, telling time, or handling money. The number system we’re most familiar with is the   decimal system , but computers use other systems, such as   binary   and   hexadecimal . Let’s break down these number systems to understand how they work. What is a Number System? A number system is a way of representing numbers using a set of symbols and rules. The most common number systems are: Decimal (Base 10) Binary (Base 2) Hexadecimal (Base 16) Each system has a different “base” that tells us how many unique digits (symbols) are used to represent numbers. Decimal Number System (Base 10) This is the system we use daily. It has  10 digits , ranging from  0 to 9 . Example: The number  529  in decimal means: 5 × 1⁰² + 2 × 1⁰¹ + 9 × 1⁰⁰ =  500 + 20 + 9 = 529 Each position represents a power of 10, starting from the rightmost digit. Why Base 10? Decimal is base 10 because it has 10 digits...

How to Monetize Your API as an Individual Developer While Hosting on Your Own Server?

In the API economy, cloud services like AWS, Google Cloud, and Azure offer many conveniences, such as scaling and infrastructure management. However, some developers prefer more control and autonomy, opting to host their APIs on personal servers. Whether for cost efficiency, data privacy, or customization, hosting your own API comes with both advantages and challenges. But, even without cloud platforms, there are effective ways to monetize your API. This guide will explore how individual developers can successfully monetize their APIs while hosting them on their own servers. Why Host Your API on Your Own Server? Hosting your own API gives you full control over the infrastructure and potentially lower long-term costs. Here’s why some developers choose this approach: Cost Control : Instead of paying ongoing cloud fees, you may opt for a one-time or lower-cost hosting solution that fits your budget and resource needs. Data Ownership : You have full control over data, which is critical if ...

The Weight of Responsibility: A Developer’s Journey to Balance Passion and Reality

For the past several years, Eddie has been on a steady climb in his career as a developer, but recently, he found himself at a crossroads — caught between the weight of his responsibilities and the desire to pursue his true passions. His journey began with a three-month internship as a web developer, which led to nearly four years in an application developer role. After that, he spent almost a year as a systems associate, managing tasks across systems analysis, quality assurance, and business analysis. Eventually, he returned to full-time software development for another two years before transitioning into more complex roles. For over a year, he worked as a multi-role software developer and database administrator before stepping into his current position as a senior software developer, database administrator, and cloud administrator — occasionally handling security tasks as well. Now, with over 8 years of professional experience, he also leads a small team of developers, which has been...

Avoiding Confusion in API Design: The Importance of Clear Responses

In today’s fast-paced software development landscape, APIs play a crucial role in connecting services and enabling functionality. However, poor design choices can lead to confusion and inefficiency for both developers and users. One such choice is the omission of a response body for successful requests, a practice I recently encountered in an enterprise API designed for bill payments. The Case of the No-Response API The API in question serves two main endpoints: one for inquiring about account validity and another for confirming payment. When successful, the API returned a  200 OK  status but no response body. This design choice led to significant confusion during our integration process. Even the internal team who developed the said API struggled to justify this approach, revealing a lack of clarity around the rationale behind it. Pros of This Design Choice While the intention behind this design may have been to streamline responses, several potential benefits can be identifi...

The Hidden Costs of Overdesign and Bad Practices in API Systems

In software development, simplicity and clarity are often sacrificed in favor of overly complex solutions. While it can be tempting to add more features and intricate designs to ensure robustness, overdesign and poor practices can have significant consequences. They frustrate developers, lead to inefficiencies, increase costs, and put unnecessary strain on system resources.  A recent example involving a team that has faced challenges with complexity highlights the pitfalls of such an approach. Overdesign: The Problem of Too Much Complexity Overdesign occurs when systems are built with more complexity than necessary. This might manifest in bloated APIs, convoluted data flows, or excessive checks and processes that don’t add substantial value. The goal is often to anticipate future problems, but this approach typically results in cumbersome systems that are difficult to maintain and scale. In one case, a company found itself paying a hefty price just to host two API services and a po...