The core team of Git LFS maintainers publishes releases on a cadence of their determining.
We follow Semantic Versioning standards as follows:
-
MAJOR
releases are done on a scale of 1-2 years. These encompass breaking, incompatible API changes, or command-line interface changes that would cause existing programs or use-cases scripted against Git LFS to break. -
MINOR
releases are done on a scale of 1-2 months. These encompass new features, bug fixes, and other "medium"-sized changes into a semi-regular release schedule. -
PATCH
releases are done on the scale of 1-2 weeks. These encompass critical bug fixes, but lack new features. They are amended to aMINOR
release "series", or, if serious enough (e.g., security vulnerabilities, etc.) are backported to previous versions.
We package several artifacts for each tagged release. They are:
-
git-lfs-@{os}-v@{release}-@{arch}.tar.gz
for the following values:operating system architecture git-lfs-darwin-386-v@{version}.tar.gz darwin 386 git-lfs-darwin-amd64-v@{version}.tar.gz darwin amd64 git-lfs-freebsd-386-v@{version}.tar.gz freebsd 386 git-lfs-freebsd-amd64-v@{version}.tar.gz freebsd amd64 git-lfs-linux-386-v@{version}.tar.gz linux (generic) 386 git-lfs-linux-amd64-v@{version}.tar.gz linux (generic) amd64 -
git-lfs-windows-v@{release}-@{arch}.zip
for the following values:operating system architecture git-lfs-windows-386-v@{version}.zip windows 386 git-lfs-windows-amd64-v@{version}.zip windows amd64 -
git-lfs-windows-v@{release}.exe
, a signed Windows installer that contains copies of both-x86
and-x64
copies of Git LFS. -
*.deb
, and*.rpm
packages for all of the distributions named inscript/packagegcloud.rb
.
We do all major development on the master
branch, and assume it to be passing
tests at all times. New features are added via the feature-branch workflow, or
(optionally) from a contributor's fork.
This is done so that master
can progress and grow new features, while
historical releases, such as v2.n.0
can receive bug fixes as they are applied
to master, eventually culminating in a v2.n.1
(and so on) release.
Let release v2.n.m
denote the version that we are releasing. When m
is
equal to 0, we say that we are releasing a MINOR version of Git LFS, in the
v2.n
-series. Let v2.n-1
denote the previous release series.
-
First, we write the release notes and do the housekeeping required to indicate a new version. On a new branch, called
release-next
, do the following:-
Run
script/changelog v2.n-1.0...HEAD
and categorize each merge commit as a feature, bug-fix, miscellaneous change, or skipped. Ensure that your~/.netrc
credentials are kept up-to-date in order to make requests to the GitHub API.This will write a portion of the CHANGELOG to stdout, which you should save into a file as well as copy and paste into
CHANGELOG.md
, along with an H2-level heading containing the version and release date (consistent with the existing style in the document.)-
Optionally write 1-2 paragraphs summarizing the release, and calling out community contributions.
-
If you are releasing a MINOR version, and not a PATCH, and if there were non-zero PATCH versions released in the
v2.n-1
series, also include any changes from the latest CHANGELOG in that series, too.
-
-
Run
script/update-version v2.n.m
to update the version number in all of the relevant files.
-
-
Then, create a pull request of your changes with head
release-next
. If you're building a MAJOR or MINOR release, set the base tomaster
. Otherwise, set the base torelease-2.n
.Run Continuous Integration, and ensure that it passes. Notify the
@git-lfs/release
team, a collection of humans who are interested in Git LFS releases. -
Once approved and verified, merge the pull request you created in the previous step. Locally, create a GPG-signed tag on the merge commit called
v2.n.m
:$ git show -q HEAD commit 9377560199b9d7cd2d3c38524a2a7f61aedc89db Merge: 3f3faa90 a55b7fd9 Author: Taylor Blau <[email protected]> Date: Thu Jul 26 14:48:39 2018 -0500 Merge pull request #3150 from git-lfs/release-next release: v2.n.0 $ git tag -s v2.n.m $ git describe HEAD v2.n.m
-
Begin building release artifacts.
-
To build
*.tar.gz
artifacts, runmake release
. -
To build
*.zip
artifacts, runmake release
(as above), and follow the additional instructions in the section "For Windows" below. -
To build
*.deb
and*.rpm
artifacts, follow the additional instructions in "For Linux" below.
-
-
Once all the assets have been built, build the signed hash file via the following:
$ (cd bin/releases && \ shasum -a256 -b * | grep -vE '(assets|sha256sums)' | \ gpg --digest-algo SHA256 --clearsign >sha256sums.asc)
-
Run
script/upload
with the tag name and the file containing the changelog entries for this version (notCHANGELOG.md
, which has all versions). This will create a new GitHub release and upload all the assets, giving them the correct labels. -
Push the tag, via:
$ git push origin v2.n.m
And publish the release on GitHub, assuming it looks correct.
-
Move any remaining items out of the milestone for the current release to a future release and close the milestone.
-
Update the
_config.yml
file ingit-lfs/git-lfs.github.com
, similar to the following:diff --git a/_config.yml b/_config.yml index 03f23d8..6767f6f 100644 --- a/_config.yml +++ b/_config.yml @@ -1,7 +1,7 @@ # Site settings title: "Git Large File Storage" description: "Git Large File Storage (LFS) replaces large files such as audio samples, videos, datasets, and graphics with text pointers inside Git, while storing the file contents on a remote server like GitHub.com or GitHub Enterprise." -git-lfs-release: 2.5.1 +git-lfs-release: 2.5.2 url: "https://git-lfs.github.com"
Then update our fork of
Homebrew/homebrew-core
similar to Homebrew/homebrew-core#32161, then celebrate.
When building a MINOR release, we introduce a new release-2.n
branch which
will receive all new features and bug fixes since release-2.n-1
. The change
set described by v2.n-1.0
and v2.n.0
is as reported by git log v2.n-1.0...master
at the time of release.
-
To introduce this new branch (after creating and merging
release-next
intomaster
), simply run:$ git branch * master $ git checkout -b release-2.n
-
Then, proceed to follow the guidelines above.
When building a PATCH release, follow the same process as above, with the additional caveat that we must cherry-pick merges from master to the release branch.
-
To begin, checkout the branch
release-2.n
, and ensure that you have the latest changes from the remote. -
Gather a set of potential candidates to "backport" to the older release with:
$ git log --merges --first-parent v2.n.m-1...master
-
For each merge that you want to backport, run:
$ git cherry-pick -m1 <SHA-1>
To cherry-pick the merge onto your release branch, adoption the first parent as the mainline.
-
Then, proceed to follow the guidelines above.
We distribute three key artifacts for Windows builds, the -x86
, and -x64
binaries embedded in a ZIP file, and the Windows installer. Before beginning,
ensure that you have a Windows VM (or access to a Windows computer) with the
following installed:
- Git for Windows
- Go (matching the version the release is built with)
- InnoSetup (available from: http://www.jrsoftware.org/isinfo.php)
- The Git LFS signing certificate (ask a maintainer for access)
- signtool.exe (available from: https://docs.microsoft.com/en-us/windows/desktop/seccrypto/signtool)
Once you have the above installed, boot up your Windows VM and run the following in a checkout of Git LFS:
-
First, run
make release-windows
. -
Copy the
bin/releases/git-windows-assets-*.tar.gz
file to your Unix system where you are doing the rest of the release and place it intobin/releases
in that Git LFS checkout. -
On your Unix system, run
make release-windows-rebuild
.
To build Git LFS *.deb
and *.rpm
packages, we first build them in
specialized Docker containers, and we upload them to PackageCloud.io.
-
To build custom versions of the Docker containers, clone
[email protected]:git-lfs/build-dockers.git
, and runbuild_dockers.bsh
. Then, run./docker/run_dockers.bsh
in the Git LFS repo withDOCKER_AUTOPULL=0
.Otherwise, run
./docker/run_dockers.bsh
in the Git LFS repo with no arguments. -
Once you have built the
*.deb
and*.rpm
files, they will appear in therepos
directory, and you can upload them to PackageCloud with:$ PACKAGECLOUD_TOKEN= ruby ./script/packagecloud.rb