Skip to content

Release Procedures

Michael Joyce edited this page May 7, 2018 · 9 revisions

Propose Release

A release candidate should be created after the community has determined that a release should occur. These steps should be followed when generating a release candidate and when completing the release.

Update Version Numbers

The version number of the release should be known at the point of release since it will have been discussed on the lists prior to the release process. However, AIT adheres to Semantic Versioning whenever possible. Review changes carefully and determine what version number increments are needed for the current release.

Append -rc#, where # indicates the current release candidate number starting at 1, when creating a release candidate.

Version Number Change Locations

AIT Core

  • setup.py - Core package version number
  • doc/source/conf.py - Documentation package version numbers

AIT GUI

  • setup.py - GUI package version number. It's very likely that a GUI release will coincide with a Core release so be sure to increment both if necessary.
  • doc/source/conf.py - Documentation package version numbers
  • ait/gui/static/package.json - GUI package version number

Update Changelog

CHANGELOG.md should be updated with changes since the previous release. Use of Github Changelog Generator is recommended and example calls that should be used are below. Otherwise, manually generating the updates is acceptable.

AIT Core

github_changelog_generator --since-tag 0.34.0 -t <your github api key> --future-release <version # for this release>

AIT GUI

github_changelog_generator --since-tag 0.21.0 -t <your github api key> --future-release <version # for this release>

Note, the --since-tag values are set to the above values to filter out changes made prior to the release to Github to ensure that issue numbers don't incorrectly link to unrelated tickets.

Build Artifacts

AIT GUI

GUI static files require NPM dependencies to be installed. From the root directory of AIT GUI:

> cd ait/gui/static
> npm run build

Commit Changes

Commit all changes made related to the release. At the minimum the commit message should include Preparation for <version> release

Tag Release

Tag the appropriate version and push to Github

> git tag <version>
> git push --tags

Email Lists

Email the lists regarding the release availability. If this is a release candidate notify the list of availability and propose a vote for release.

Release Candidate Example

TODO

Nominal Release Example

TODO

Clone this wiki locally