nbgv
CLI tool
The nbgv
CLI tool is useful for all repos regardless of ecosystem.
The tool is distributed as a .NET CLI tool.
Perform a one-time install of the nbgv
tool by acquiring it from the NuGet gallery.
The CLI command for installation is typically:
dotnet tool install -g nbgv
You may then use the nbgv
tool to install Nerdbank.GitVersioning into your repos, as well as query and update version information for your repos and projects.
Install Nerdbank.GitVersioning into your repo using this command from within your repo:
nbgv install
This will create your initial version.json
file.
It will also add/modify your Directory.Build.props
file in the root of your repo to add the PackageReference
to the latest Nerdbank.GitVersioning
package available on nuget.org.
CI Builds
If scripting for running in a CI build where global impact from installing a tool is undesirable, you can localize the tool installation:
dotnet tool install --tool-path my/path nbgv
Ensure your custom path is outside of your git repository, as the
nbgv
tool doesn't support uncommited changes
At this point you can launch the tool using ./nbgv
in your build script.
Preparing a release
The prepare-release
command automates the task of branching off the main development branch to stabilize for an upcoming release. It is optimized for the following workflow:
- There is a branch (typically
master
) where main development happens. This branch typically builds with some-prerelease
tag. It may be a "public release" for early prereleases. - To stabilize for and/or ship a release, a branch named after the version to be shipped is created.
This branch may include a
-prerelease
tag, typically a more advanced tag than any found inmaster
. For example, ifmaster
builds-alpha
then the stabilization branch would build-beta
or-rc
. - Each release branch may be periodically merged into the next newer release branch or
master
so that hot fixes also ship in the next major release.
The prepare-release
command supports this working model by taking care of
creating the release branch and updating version.json
on both branches.
To prepare a release, first ensure there is no uncommited changes in your repository then run:
nbgv prepare-release
This will:
- Read
version.json
to ascertain the version under development, and the naming convention of release branches. - Create a new release branch for that version. If the version on the current
branch is
1.2-beta
and the release branch naming convention isrelease/v{version}
, a release branch namedrelease/v1.2
will be created. - Remove the prerelease tag from
version.json
on the release branch. Optionally (if an argument is passed to the command) a new prerelease tag is used to replace the old one. - Back on the original branch, increment the version as specified in
version.json
. By default,prepare-release
will increment the minor version and set the prerelease tag toalpha
. If the version has multiple prerelease tags (separated by '.'), only the first tag will be updated. In the above example, the version on the main branch would be set to1.3-alpha
. - Merge the release branch back to the main branch, resolving the conflict in
version.json
. This avoids having to resolve the conflict when merging the branch at a later time.
You can optionally include a prerelease tag on the release branch, e.g. when you want to do some stabilization first. This can be achieved by passing a tag to the command, e.g.:
nbgv prepare-release rc
Note: When the current branch is already the release branch for the current version, no new branch will be created. Instead the tool will just update the version in the current branch by replacing or removing the prerelease tag.
Customizing the next version
By default, the next version of the main branch is determined from the current
version and the versionIncrement
setting in version.json
.
To customize this behaviour, you can either explicitly set the next version
or override the version increment setting.
To explicitly set the next version, run:
nbgv prepare-release --nextVersion 2.0
To override the versionIncrement
setting from version.json
, run:
nbgv prepare-release --versionIncrement Major
Note: The parameters nextVersion
and versionIncrement
cannot
be combined.
Customizing the behaviour of prepare-release
The behaviour of the prepare-release
command can be customized in
version.json
:
{
"version": "1.0",
"release": {
"branchName" : "release/v{version}",
"versionIncrement" : "minor",
"firstUnstableTag" : "alpha"
}
}
Property | Default value | Description |
---|---|---|
branchName | v{version} |
Defines the format of release branch names. The value must include a {version} placeholder. |
versionIncrement | minor |
Specifies which part of the version on the current branch is incremented when preparing a release. Allowed values are major , minor and build . |
firstUnstableTag | alpha |
Specified the unstable tag to use for the main branch. |
Customizing the prepare-release
output format
By default, the prepare-release
command writes information about created and updated branches to the console as text.
Alternatively the information can be written to the output as json
.
The output format to use can be set using the --format
command line parameter.
For example, running the following command on master
nbgv prepare-release --format json
will generate output similar to this:
{
"CurrentBranch": {
"Name": "master",
"Commit": "5a7487098ac1be1ceb4dbf72d862539cf0b0c27a",
"Version": "1.7-alpha"
},
"NewBranch": {
"Name": "v1.7",
"Commit": "b2f164675ffe891b66b601c00efc4343581fc8a5",
"Version": "1.7"
}
}
The JSON object has two properties:
CurrentBranch
provides information about the branch thatprepare-release
was started on (typicallymaster
)NewBranch
provides information about the new branch created by the command.
For each branch, the following properties are provided:
Name
: The name of the branchCommit
: The id of the latest commit on that branchVersion
: The version configured in that branch'sversion.json
Note: When the current branch is already the release branch for the current version, no new branch will be created.
In that case, the NewBranch
property will be null
.
Customizing the prepare-release
commit message
By default, the prepare-release
command generates a commit message with the format "Set version to {version}".
A switch allows you to customize the commit message, using {0}
as a placeholder for the version.
For example, running the following command:
nbgv prepare-release --commit-message-pattern "Custom commit message pattern - {0} custom message"
So your commit message is going to be this:
Custom commit message pattern - 1.0 custom message
Creating a version tag
The tag
command automates the task of tagging a commit with a version.
To create a version tag, run:
nbgv tag
This will:
- Read version.json to ascertain the version under development, and the naming convention of tag names.
- Create a new tag for that version.
You can optionally include a version or commit id to create a new tag for an older version/commit, e.g.:
nbgv tag 1.0.0
Customizing the behaviour of tag
The behaviour of the tag
command can be customized in version.json
:
{
"version": "1.0",
"release": {
"tagName" : "v{version}"
}
}
Property | Default value | Description |
---|---|---|
tagName | v{version} |
Defines the format of tag names. Format must include a placeholder '{version}' for the version. |
Learn more
There are several more sub-commands and switches to each to help you build and maintain your projects, find a commit that built a particular version later on, create tags, etc.
Use the --help
switch on the nbgv
command or one of its sub-commands to learn about the sub-commands available and how to use them. For example, this is the basic usage help text:
nbgv --help
usage: nbgv <command> [<args>]
install Prepares a project to have version stamps applied
using Nerdbank.GitVersioning.
get-version Gets the version information for a project.
set-version Updates the version stamp that is applied to a
project.
tag Creates a git tag to mark a version.
get-commits Gets the commit(s) that match a given version.
cloud Communicates with the ambient cloud build to set the
build number and/or other cloud build variables.
prepare-release Prepares a release by creating a release branch for
the current version and adjusting the version on the
current branch.