Cirq is currently (as of May 2020) alpha, and so has a MAJOR version
of 0. Below is info on how we version releases, and how the releases
themselves are created. Note that development is done on the master
branch, so if you want to use a more stable version you should use one
of the releases or
install from pypi using pip install cirq
. The release from the
latest commit to master can be installed with pip install cirq-unstable
.
We follow semantic versioning for labeling our releases. Versions are labeled MAJOR.MINOR.PATCH where each of these is a numerical value. The rules for versions changes are:
- Before MAJOR becomes 1, updates to MINOR can and will make changes to public facing apis and interfaces.
- After MAJOR becomes 1, updates that break the public facing api or interface need to update MAJOR version.
- MINOR updates have to be backwards compatible (after MAJOR>=1).
- PATCH updates are for bug fixes.
Versions based on unreleased branches of master will be suffixed with ".dev".
We use github's release system for creating releases. Release are listed on the Cirq release page.
Our development process uses the master
branch for development.
Master will always use the next unreleased minor version with the suffix
of ".dev". When a release is performed, the ".dev" will be removed and tagged
in a release branch with a version tag (vX.X.X). Then, master will be updated
to the next minor version. This can always be found in the
version file.
This procedure can be followed by authorized cirq developers to perform a release.
Make sure you're on an up-to-date master branch and in cirq's root directory.
git checkout master
git pull origin master # or upstream master
git status # should be no pending changes
Ensure you have pypi and test pypi accounts with access to cirq distribution. This can be done by visiting test.pypi.org, logging in, and accessing the cirq distribution.
For the following script to work, you will need the following env variables defined: TEST_TWINE_USERNAME, TEST_TWINE_PASSWORD, PROD_TWINE_USERNAME, PROD_TWINE_PASSWORD.
It is highly recommended to use different passwords for test and prod to avoid accidentally pushing to prod.
Also define these variables for the versions you are releasing:
VER=VERSION_YOU_WANT_TO_RELEASE # e.g. "0.7.0"
NEXT_VER=NEXT_VERSION # e.g. "0.8.0"
Create a release branch called "v${VERSION}-dev":
git checkout master -b "v${VER}-dev"
vi _version.py # Remove .dev from version
git add _version.py
git commit -m "bla bla"
git push origin "v${VER}-dev"
git checkout master -b "version_bump_${NEXT_VER}"
vi _version.py # Bump version to next version. KEEP .dev!
git add _version.py
git commit -m "bla bla"
git push origin "version_bump_${NEXT_VER}"
Master branch should never see a non-dev version specifier.
From release branch, create a binary distribution wheel. This is the package that will go to pypi.
git checkout "v${VER}-dev"
python3 setup.py -q bdist_wheel
ls dist # should only contain ONE file
The package server pypi has a test server where packages can be uploaded to check that they work correctly before pushing the real version. This section illustrates how to upload the package to test pypi and verify that it works.
First, upload the package in the dist/ directory. (Ensure that this is the only package in this directory, or modify the commands to upload only this file).
twine upload --repository-url=https://test.pypi.org/legacy/ -u="$TEST_TWINE_USERNAME" -p="$TEST_TWINE_PASSWORD" "dist/*"
Next, run automated verification.
Note: sometimes the first verification from test pypi will fail.
# NOTE: THE FIRST RUN WILL LIKELY FAIL
./dev_tools/packaging/verify-published-package.sh "${VER}" --test
Once this runs, you can create a virtual environment to perform manual verification as a sanity check and to check version number and any high-risk features that have changed this release.
mkvirtualenv "verify_test_${VER}" --python=/usr/bin/python3
pip install -r requirements.txt -r cirq/contrib/contrib-requirements.txt -r dev_tools/conf/pip-list-dev-tools.txt
pip install --index-url=https://test.pypi.org/simple/ cirq=="${VER}"
python -c "import cirq; print(cirq.__version__)"
python # just do some stuff checking that latest features are present
Put together a release notes document that can be used as part of a release and for an announcement email.
You can model the release notes on the previous release from the Release page.
Retrieve all commits since the last release with:
git log "--pretty=%h %s
.
You can get the changes to the top-level objects and protocols by checking the history of the init file
Upload to prod pypi using the following command:
twine upload --username="$PROD_TWINE_USERNAME" --password="$PROD_TWINE_PASSWORD" "dist/*"
Perform automated verification tests:
# NOTE: FIRST RUN WILL LIKELY FAIL
./dev_tools/packaging/verify-published-package.sh "${VER}" --prod
Next, create a virtual environment to perform manual verification of the release.
mkvirtualenv "verify_${VER}" --python=/usr/bin/python3
pip install cirq
python -c "import cirq; print(cirq.__version__)"
Using the information above, create the release on the Release page. Be sure to include the whl file as an attachment.
Lastly, email cirq-announce@googlegroups.com with the release notes and an announcement of the new version.
Congratulate yourself for a well done release!