-
-
Notifications
You must be signed in to change notification settings - Fork 266
ReleaseManagement
The following are step by step instructions on how to package a release.
Make sure the source builds and works locally, and the docs build with no errors
Make sure the source passes Travis CI, OGC CITE tests and unit tests
Create a release tag against master:
- update desired branch with
x.y.z
inpygeoapi/__init__.py
anddocs/source/conf.py
- update changelog information in
debian/changelog
- commit the above updates:
# in branch master
git commit -m 'update release version' pygeoapi/__init__.py docs/source/conf.py debian/changelog
git push origin master # or branch if releasing from a branch
Release tags are in the format x.y.z
If releasing from master:
git tag -a x.y.z -m 'tagging x.y.z'
git push --tags
If releasing from a branch:
git checkout x.y
git tag -a x.y.z -m 'tagging x.y.z'
git push --tags
Release to PyPI:
python3 setup.py sdist bdist_wheel --universal
twine upload dist/*
Create Docker Image on DockerHub for release/tag (you'll need permission for that repo on DockerHub):
- Go to pygeoapi DockerHub Builds Page.
- Press the blue button "Configure Automated Builds"
- Under "Build Rules" press the '+' button
- In new build rule choose: Source Type
tag
and fill-in new tagx.y.z
in Source and Docker Tag columns - Disable toggle Build Caching in last column
- Press the button Save (Save and Build will build all tagged Images!)
- Press the button Trigger Build
- Inspect the build progress (may take up to 15 mins!) on builds
Upgrade stable
version of pygeoapi
on demo.pygeoapi.io/stable. Not automated yet!
Requires changes within the demo.pygeoapi.io GH repo and the demo server:
- edit/commit/push docker-compose file: set new version tag
x.y.z
ofimage: geopython/pygeoapi: x.y.z
- login with admin account on demo server
demo.pygeoapi.io
cd git
- pull changes on server:
./refresh-git.sh
- no rebuild needed, only possible changes in local.config.yml if config-conventions have changed
- restart:
cd git/services/pygeoapi_stable
- restart:
./stop.sh
then./start.sh
Update https://github.com/geopython/pygeoapi.io/blob/master/docs/download.md
Push updates
git commit -m 'update release' docs/download.md
git push origin master
mkdocs gh-deploy --force -m 'update release'
Add the x.y.z documentation to readthedocs.org
- go to https://readthedocs.org/projects/pygeoapi
- under 'Build a version', select 'latest' and click 'Build'
- this will cause readthedocs.org to sync release tags, new version will appear
- go to https://readthedocs.org/projects/pygeoapi/versions
- find x.y.z
- click 'Active' and ensure visibility is set to 'Public'
- click 'Submit'
- Update mailing list:
The pygeoapi team announces the release of pygeoapi x.y.z.
<release highlights>
Source and binary downloads:
----------------------------
The source code is available at:
https://pygeoapi.io/download
PyPI packages are available at:
https://pypi.org/project/pygeoapi
Version x.y.x (YYYY-MM-DD)
--------------------------
[Bulleted list of enhancements / bug fixes]
All contributions are always welcome.
The pygeoapi team
https://pygeoapi.io
-
Tweet release from the pygeoapi Twitter account with link to announcement from mailing list
-
Update the OSGeo project page if features have been updated (i.e. new standard support, etc.) x
Update version in master back to dev (x.y.dev0)