/git-notary

git-notary generates canonical version tags from versioning notes.

Primary LanguageShellMIT LicenseMIT

git-notary

Overview

git-notary generates canonical version tags from versioning notes.

Why would I want this?

git-notary may be helpful if you want to use Semantic Versioning in a project with many contributors and some manner of branch-oriented workflow. Tracking versioning information with a VERSION file seems like a great idea, but has some quirks.

An Example Scenario

Consider the following (simplified) scenario:

*   e44e210 - (HEAD -> develop) Merge branch 'bar' into develop
|\
| * e1793f3 - (bar) PATCH
| * f231d3b - MAJOR 
| * 5c69653 - MAJOR
* |   67543e1 - Merge branch 'foo' into develop
|\ \
| |/
|/|
| * ea81623 - (foo) MAJOR
| * 8b773db - PATCH
| * 6613b79 - MINOR
|/
* 21c36f3 - (master) MINOR
* 64357c2 - MINOR
* 9ebfd7d - MINOR
* cc5d832 - PATCH
* ebc851f - MINOR
* a75790f - PATCH
* 572a9e8 - MAJOR
* a990127 - (tag: 0.0.0) INITIAL

In this example, two branches (foo and bar) were created from master (21c36f3). Both branches know that 1.4.0 is the latest tag (at the time they branched). Let’s assume these branches do not conflict with each other.

With a VERSION file, a project generally chooses one of two places to update it:

  • Updates occur in the branch. In this case, once either branch is merged, the other is in conflict with it.
  • Updates occur in the trunk. In this case, the trunk now contains code that did not originate in a branch. Again, the first merged is safe, but the other is in a conflicting state.

If foo merges first, the expected version post-merge is 2.0.0.

If bar merges first, the expected version is 3.0.1.

At e44e210 (HEAD of develop), the final version should be 4.0.1, but if the merge order were reversed, it should be 4.0.0. This gets worse as the number of active branches increases.

Assumptions

  • Versioning is important.
  • Versions should communicate scope of change.
  • Humans can signal the scope of their own changes.
  • Machines can figure out the rest.

Installation

Install via RubyGems

gem install git-notary

Manual Installation

Download the latest release of git-notary and place it somewhere in your $PATH.

Usage

Add new versioning information

git-notary new <version> [object] [namespace]

Where <version> is one of (major, minor, patch).

Undo a version

git-notary undo [object] [namespace]

Fetch versioning notes

git-notary fetch [remote] [namespace]

Fetch and merge versioning notes

git-notary pull [remote] [namespace] [merge-strategy]

Push versioning notes

git-notary push [remote] [namespace]

Extract Notes

git-notary notes [branch] [base] [namespace]

Compute Versions from Notes

git-notary notes | git-notary versions [initial]

Generate Tags from Versions

git-notary notes | git-notary versions | git-notary tags [--apply]

License

git-notary is available under the MIT License. See LICENSE.txt for the full text.

Contributors