Skip to content
Tom Kralidis edited this page Mar 11, 2024 · 29 revisions

The following are step by step instructions on how to package a release.

Building the Release Packages

Source Code

Step 1

Make sure the source builds and works locally, and the docs build with no errors

Step 2

Make sure the source passes GitHub Actions CI, OGC CITE tests and unit tests

Step 3

Create a release tag against master:

  • update desired branch with x.y.z in pygeoapi/__init__.py and docs/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/*

Step 4

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 tag x.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

Step 5

Upgrade stable version of pygeoapi on demo.pygeoapi.io/stable. Not automated yet! Requires changes within the demo.pygeoapi.io GitHub repo and the demo server:

  • edit/commit/push services/pygeoapi_stable/docker-compose.yml: set new version tag x.y.z of image: geopython/pygeoapi: x.y.z
  • edit/commit/push services/pygeoapi_stable/local.config.yml: set new version in metadata.identification.title
  • 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.shthen ./start.sh

Step 6

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

Step 7

Add the x.y.z documentation to readthedocs.org

Step 8

  • 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

Step 9

Create a release on GitHub.

  • Go to https://github.com/geopython/pygeoapi/releases
  • Click 'Draft a new release'
  • Under 'Tag Version' add the relevant release tag (x.y.z)
  • Release title should be pygeoapi x.y.z
  • Release description should be:
    • major or minor releases: pygeoapi x.y.z has been released. See the [release announcement](URL) for more information.
      • URL should be a link to the announcement made on the pygeoapi mailing list
    • patch/bugfix releases: pygeoapi x.y.z has been released. This release is a maintenance/bugfix release.

Step 10

Update version in master back to dev (x.y.dev0)

Clone this wiki locally