Skip to content

Release Procedure

Hyungro Lee edited this page Feb 10, 2020 · 9 revisions
  • Release Manager: HL

Preconditions for Release:

  1. If the release is a milestone release: no open tickets for the milestone
  2. Travis CI on devel is passing (http://ci.radical-project.org/job/radical.entk.devel/branch/devel/)

Release process; regular

  1. Create a branch from the latest master: e.g. git checkout master; git pull; git checkout -b release/1.0.1
  2. Update the version file: echo "1.0.1" > VERSION
  3. Make modifications to the branch: followed by merging devel git merge devel (make sure to pull devel before)
  4. Update release notes: $EDITOR CHANGES.md
  5. Commit and push: git commit -a; git push release/1.0.1
  6. Create pull-request of release branch to the master (base): https://github.com/radical-cybertools/radical.entk/pulls
  7. Wait on and/or nudge other developers to review and test
  8. If not approved, GOTO 3

Release process; hotfix

  1. Create a branch from the latest master: e.g. git checkout master; git pull; git checkout -b hotfix/issue_123
  2. Update version echo "1.0.1" > VERSION
  3. Make modifications to the branch: either by $EDITOR or git cherry-pick abcsuperdupercommit890 (The latter is preferred)
  4. Update release notes: $EDITOR CHANGES.md
  5. Commit and push: git commit -a; git push hotfix/issue_123
  6. Create pull-request of hotfix branch to the master(base): https://github.com/radical-cybertools/radical.entk/pulls
  7. Wait on and/or nudge other developers to review and test
  8. If not approved, GOTO 3

Publishing a release

  1. If approved, move to master branch and pull in the merged content: git checkout master, then git pull
  2. Create tag: git tag -a v1.0.1 -m "release v1.0.1.2"
  3. Push tag to GitHub: git push --tags
  4. Release on PyPI: python setup.py sdist; twine upload --skip-existing dist/radical.entk-1.0.1.tar.gz
  5. Verify PyPI version on: https://pypi.python.org/pypi/radical.entk

Post Release

  1. Merge master into devel branch: git checkout devel; git merge master; git push origin devel
  2. Merge devel into all open development branches: for b in $branches; do git checkout $b; git merge master; done
  3. Delete the branch for the release e.g. release/1.0.1 or hotfix/issue_123