Skip to content

πŸ‘©β€πŸ’»πŸ‘¨β€πŸ’» A Kata to practice rewriting history towards a Clean Git History ✨

License

Notifications You must be signed in to change notification settings

andrej-dyck/git-kata

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

26 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

Git Kata - Clean History

Git Logo

A clean Git history is beneficial to a project in many ways. Similar to how clean code documents the current state of the software, a well-tended Git log documents what changes happened and why. For example,

  • What are the design decision in a pull request?
  • What has happened since the last fetch?
  • Why did the implementation of a function change?
  • Was this a refactoring or a change in functionality?
  • When did the bug got introduced? (supported by git-bisect)

However, good commit messages are not enough for a clean Git history, and we need tend to and refactor our history before we "commit" to it; or in other words, rewrite the history. For all the questions above, we want to have coherent, small, and working commits. Further, a linear history helps to comprehend the sequence of changes more easily.

To visualize this, we want to go from this kind of Git log (here, only 3 developers worked in parallel)

Git merge

to this kind of linear history (here, 5 developers worked in parallel)

Git rebase

or even as linear as OneFlow.

Git oneflow

Note: This kata assumes that you are already have basic Git knowledge, like how to stage files, commit changes, push to origin, fetch and pull from remote, branching, and work with the Git log.


Quick Start

  • Ensure the latest Git is installed and available in the shell
  • Navigate to the folder of an exercise; e.g., <kata-root>/101-local-amend-commit
  • Run the ./init.sh in that folder
    • On Windows, use Git BASH or other Bash emulators (e.g., cmder)
    • On Mac OS X, checkout the branch main-osx
  • Navigate to the created/updated folder <kata-root>/exercise with your favorite Git client
  • Consult the README.md in that folder for the description and task

With IntelliJ (optional)

This is optional, if you want to have compiler support of IntelliJ and/or use its integrated Git client.

  • Open this Gradle project with IntelliJ
    • You can use the free Community Edition
    • On Windows, set Settings > Tools > Terminal > Shell path to "<system-path-to-git>\bin\bash.exe" --login -i (see Note)
  • In the project view, right-click the init.sh of an exercise and run it with Run 'init.sh'
  • Select the created/updated folder <kata-root>/exercise and open the Git tool window (ALT+9)
    • If you cloned this repository, in the Git Log window, chose the filter Paths: exercise
  • Consult the README.md in that folder for the description and task

Note

The init scripts for this kata are bash scripts, at the moment. Thus, you need a Bash to execute them. Fortunately for Windows, the Git Bash is a shell that can execute those scripts.


Links and Resources

The Git version control system

Katas inpired by

Naming conventions

Workflows

Merge & Rebase

Tutorials & Talks

Recommended Git Clients

Other Tools

About

πŸ‘©β€πŸ’»πŸ‘¨β€πŸ’» A Kata to practice rewriting history towards a Clean Git History ✨

Topics

Resources

License

Stars

Watchers

Forks