-
Notifications
You must be signed in to change notification settings - Fork 889
Development: Release Process
This document describes the process for creating an Open GEE release.
Open GEE version numbers are designed to work well with package managers like
yum and apt. In yum and apt, 5.2.5-714.9
comes after 5.2.5
. Thus, all
version numbers for Open GEE have a dash followed by a build number. This
build number can be prepended with a b
to indicate the build is not a
releasable build (was not built from a properly created release branch).
To find the version string associated with the head of a particular branch check out the branch you want to get the version string from and run the following command:
$ git checkout release_5.2.5
$ ./earth_enterprise/src/scons/getversion.py -l
5.2.5-714.9
You will need to get the version string of a release branch to perform some of the steps below
Once work on a release has been completed:
-
Select the new release number
Use the principles of semantic versioning to select the new release number.
-
Update documentation
Make the following documentation updates and then commit them to the master branch. It is important to make these changes on the master branch before creating the release branch to make it easier to merge the release branch into the master branch.
- Create release notes for the new release. Pattern it after the existing release notes earthenterprise/docs/geedocs/docsrc/answer/releaseNotes/relNotesGEE5_3_2.rst.
- Include the new rst file in earthenterprise/docs/geedocs/docsrc/answer/releaseNotes.rst.
- Update the copyright with the current year in earthenterprise/docs/geedocs/docsrc/conf.py.
- Generate html for documentation (Whenever there is a change in rst, we need to generate html
and commit the changes)
you will see that based on the current release number, the folder will be created under earthenterprise/docs/geedocs
$ cd earthenterprise/docs/geedocs/docsrc $ rm -rf build $ make html
Commit these changes to the master branch.
-
Update version number
The following files need to be updated with the latest version number.
- earth_enterprise/src/support/geecheck/geecheck.pl (2 places)
- earth_enterprise/src/fusion_version.txt
- earth_enterprise/src/fusion/portableglobe/cutter/cgi-bin/geecheck_tests/common.py
- earth_enterprise/Upgrade.md (several places)
- earth_enterprise/src/fusion/portableglobe/servers/local/preview/help.html: update the version number (x.y.z) in the two links, shown below, to be the latest version number https://www.opengee.org/geedocs/x.y.z/answer/geeServerAdmin/createPortableGlobesMaps.html https://www.opengee.org/geedocs/x.y.z/answer/portable/portableDeveloperGuide.html
Commit these changes to the master branch
Note: many times this is done early in the release, so these changes may have been made already.
-
Update Supported Platforms
If necessary, update the supported platforms and versions in src/fusion/portableglobe/cutter/cgi-bin/geecheck_tests/user_tests/common.py. Commit these changes to the master branch.
-
Create the first release candidate tag
Create the first release candidate tag from latest commit on master. The tag should be
X.Y.Z-RC1
whereX.Y.Z
is the version number.Use git annotated tags for creating tags, so we can keep track of who made the tag. (If you don't use annotated tags, then GitHub will report the author of the tag as the author of the last commit, rather than the user who created the tag.)
Example:
$ git checkout master $ git tag -a 5.2.5-RC1 -m "Open GEE 5.2.5 Release Candidate 1"
-
Create release branch
Create a release branch named
release_X.Y.Z
whereX.Y.Z
is the release number. This branch should be based on the RC1 tag you just created in the previous step. Then push the release branch to GitHub.Example:
$ git checkout -b release_5.2.5 5.2.5-RC1 $ git push --follow-tags -u origin release_5.2.5
-
Update master
Create an alpha tag for next version on the master branch:
Example:
$ git checkout master $ git commit --allow-empty -m "Start of release 5.2.6" $ git tag -a 5.2.6-1.alpha -m "Open GEE 5.2.6 Alpha release"
Then you need to change the same files as in the Update version number step to ensure that master is now the next version (example 5.2.6).
Then commit and push the changes:
$ git commit -a $ git push --follow-tags -u origin master
-
Create the first pre-release in Github
If you have committed any changes to the release branch after creating the RC1 tag, create a new RC by repeating the step "Create the first release candidate tag" (but with a tag that ends in RC2).
Then follow the instructions at https://help.github.com/articles/creating-releases/. Be sure to specify the release candidate tag you just created and indicate that it is a pre-release.
-
Create a source archive artifact for the release
The default GitHub release process is not really compatible with git-lfs, which is used by the earthenterprise repo. It will create source archive files which do not include the actual git-lfs files, instead just the links to them.
Also, version files that are needed for the build process are generated by tags within the git repository. These version files need to be added to the archive file to make the source within that file build-able without git.
Therefore, additional steps are required to create the full source plus git-lfs binary files and the needed version files.
Note: This process needs to be done for all pre releases as well as the final release.
-
Cd into the
scripts
directory underearthenterprise
. -
Run the
build_release_archive.sh
script, specifying the release branch from the repo to package. e.g../build_release_archive.sh release_5.2.5
-
After the script has run and created the archives
earthenterprise.tar.gz
andearthenterprise.zip
, rename them to include the version string (see above for the command to retrieve the version string), so that it's clear what the archive contains. e.gmv earthenterprise.tar.gz earthenterprise-5.2.5-714.9.tar.gz
-
Edit the release page to upload these 2 additional files. For an example, see [Open GEE 5.2.5 Release] (https://github.com/google/earthenterprise/releases/tag/5.2.5-714.9)
-
-
Build and test release
Testing should be done on all supported operating systems. The test systems should be clean VMs or docker images that have not been used to build or run Open GEE previously. Testers should test the latest release candidate.
If testing reveals any bugs that need to be fixed, those fixes should be applied to the release branch. The release branch can be merged into master immediately to make those changes available in master. Otherwise, the changes will be merged into master when the release is complete.
Each time a new set of fixes is applied to the release branch, a new release candidate should be generated and regression testing should be performed. The tag for the new release candidate should be
X.Y.Z-RCN
whereX.Y.Z
is the version number andN
is one more than the previous release candidate number (initially as stated above RC1).As was done with the first pre-release tag use git annotated tags for creating subsequent pre-release tags, so we can keep track of who made the tag. Also follow the same instructions as was followed for creating the first release candidate to publish all subsequent release candidates.
-
Update release notes
Update the release notes to cover the significant changes made during the release as well as any bugs fixed while testing. Remember to generate html and commit any release notes changes to the release branch.
To see all changes that were committed since the previous release, run the following command, changing the release numbers as appropriate:
git log --pretty=oneline --abbrev-commit release_5.3.0 ^release_5.2.5
-
Create the release in Github
Once a pre-release candidate is declared good to release then apply a release tag which will match the version string outputted from the version string command (see above for the version string command to run to get this string).
NOTE: the head of the release branch should be pointing to the latest release candidate at this point. For example, if the 3rd release candidate was declared to be the one that will be shipped then the head of the release branch in the above example should be pointing to the tag
5.2.5-RC3
.Release tag example:
$ git tag -a 5.2.5-714.9 -m "Open GEE 5.2.3 Final" $ git push origin 5.2.5-714.9 Where: origin is pointing to official Open GEE repository and '5.2.5-714.9' is an example for the build number. To get build number, run `getversion.py` (https://github.com/google/earthenterprise/blob/master/earth_enterprise/src/scons/getversion.py)
Again follow the instructions at https://help.github.com/articles/creating-releases/. But this time specify the final release tag you just created and do not select 'this release is a pre-release'.
-
Merge changes back into master
Merge the release branch back into master so that any changes made during the release are included in master. This may involve resolving some merge conflicts if other work has already been merged into master.
-
Copy docs for next release
This step can be done on master at any point after the release branch is created. The main concern is to ensure that changes for the following release don't end up in this release. On the master branch:
-
Create release notes for the new release. Pattern it after the existing release notes earthenterprise/docs/geedocs/docsrc/answer/releaseNotes/relNotesGEE5_3_2.rst.
-
Include the new rst file in earthenterprise/docs/geedocs/docsrc/answer/releaseNotes.rst.
-
Update the copyright with the current year in earthenterprise/docs/geedocs/docsrc/conf.py.
-
Generate html for documentation (Whenever there is a change in rst, we need to generate html and commit the changes)
$ cd earthenterprise/docs/geedocs/docsrc $ rm -rf build $ make html
you will see that based on the next release number in the master, the folder will be created under earthenterprise/docs/geedocs
-
Edit earthenterprise/docs/_data/versions.yml to add new entry for the new version to the head of the list. Also indicate that this version is under development.
-
Update symlinks to the newest development documents:
cd earth_enterprise/docs/landing_page rm manual ln -s ../../../docs/geedocs/5.2.6 manual
-
Commit these changes to the master branch.
-
-
Update README.md and stable version
Update the main README.md page for the Github repo to include a link to the latest release and the latest docs.
Update the version status from "unstable" to "latest stable" in versions document.
-
Delete pre-release RC tags
This is an optional step but if done it must be done after creating the final and permanent release tag for the release. Also, clean up the corresponding releases on the release page.
The release branch can be merged into master at any point during the release process to bring changes made for the release into the master branch. This may be necessary to bring fixes that were included on the release branch into master in a timely manner. The release branch can be merged into master multiple times, so you can continue doing work on the release branch after merging it into master. Keep in mind, however, that this will publish any documentation changes from the release branch (such as the release notes) on opengee.org. Also note that you may have to resolve merge conflicts if other work has already been merged into master since the release branch was created. If changes do not need to be brought into master immediately you can wait until the end of the release process when all changes will be merged to master.
It was mentioned earlier that a new release branch is started from the latest commit of the master branch. This is not always the case. It is possible to create a release based on a previous release. This is done for a couple of reasons and there are two methods for doing this. Which one you use depends on the needs of the release.
Sometimes despite all the testing a critical bug can slip by and get shipped
with the release. If the bug is critical enough and is low risk the best approach
might be to re-open the release with the bug and fix the bug in that release
branch. The new release will have the same version number (e.g. 5.2.5
) but will
be distinguished from previous releases with that same version number by its build
number (i.e. 5.2.5-714.9
vs 5.2.5-714.10
). To re-open a release you just need
to be sure that the RC1
tag for that release branch still exists. If it was deleted
then you can recreated it using the build number form the last build of the release
you shipped.
Example if the previous shipped build was 5.2.5-714.9
:
git tag -a 5.2.5-RC1 "$(git rev-list --max-count=1 --skip=9 --topo-order 5.2.5-714.9)" -m "release candidate 1 for 5.2.5"
Once you have the first release candidate tag you can then follow the same release described above. Note: a release branch can produce multiple release builds.
Sometimes is is desired to ship an urgently needed feature before the next major
release is shipped. In this case you might want a new version number to make the
two builds even more distinguishable from each other. In this case you would create
a new release branch based off of the latest commit on the previous release you want
this new release to be based on. You should pick a new version number for this
release branch and that number should extend the version number based on the previous
release. For example if your previous release was 5.3.0
you would want to use 5.3.1
.
However, if the release you are basing this new release on had a version number of
5.2.5
then you want to make a 4 part version number and have 5.2.5.1
as this new
release version number. Other than what you based the new release branch on and
how you pick the version number the rest of the process is the same as described above.