The release process in Rally is automated as much as possible. Suppose you want to release Rally 1.2.0. Then just run make release release_version=1.2.0 next_version=1.2.1
. The parameter release_version
refers to the release that is being released and the parameter next_version
refers to the next development version.
This will automatically run all tests (including integration tests), build and upload all artifacts and update the changelog and the list of contributors.
It is recommended to run make release-checks release_version=1.2.0 next_version=1.2.1
before the release. The script will check for the requirements mentioned in Preconditions and the Initial setup.
- Close milestone on Github: https://github.com/elastic/rally/milestones.
- Prepare offline installation package
source scripts/offline-install.sh "${RELEASE_VERSION}"
. - Upload offline install package to Github: https://github.com/elastic/rally/releases/edit/$RELEASE_VERSION.
- Build and publish Docker image using the CI job: Build and publish Docker image using: https://elasticsearch-ci.elastic.co/view/All/job/elastic+rally-release-docker+master specifying the $RELEASE_VERSION
- Announce on Discuss: https://discuss.elastic.co/c/annoucements.
- Ensure that the master branch is checked out and your working copy is clean (run
git status
). - Ensure that the associated milestone on Github contains no open tickets (otherwise the release will fail).
In order to automatically generate the changelog, setup a personal Github access token with permission public_repo
(see https://github.com/settings/tokens). Store the token in ~/.github/rally_release_changelog.token
.
The release process requires a valid gpg key configured both locally and on GitHub. Please follow the instructions to set your gpg for git.
It also requires:
- A PyPI account with admin access for the esrally project in order to upload the release.
- A Readthedocs account with admin access for the esrally project in order to maintain the documentation.
- GPG is properly setup for signing the release tag for your git user (see
git config user.name
andgit config user.email
).