Making a new release is currently a manual, multi-step process:
- check that all test are passing (in particular, all data sources are reachable)
- check the changelog and determine the next version (see below)
- update the
CHANGELOG.md
such that it states the new version on top and doesn't contain any unreleased entries - create a git tag named
vX.Y.Z
according to the new version - update the
CHANGELOG.md
such that it contains a new(unreleased)
placeholder for upcoming changes - create the release on github
- ensure the release is propagated to zenodo
The version numbers are adapted from the SEMVER scheme: MAJOR.MINOR.PATCH
.
In order to decide for the new version number, please check the CHANGELOG.md
.
Depending on the kind of changes since the last release, it will be a MAJOR
, MINOR
or PATCH
release, according to the following table.
If multiple kinds apply, the highest wins (e.g. on MINOR
and MAJOR
changes, it will be a MAJOR
release).
| change | (minimum) release kind | |:---:|:---:|:---:| | add a new endpoint (🔵) | minor | | delete a previously existing endpoint | major | | change the content returned by an endpoint (e.g. data version updates) | major | | change the source location of an endpoint (e.g. from one server to another) | major (❗) | | moving / renaming an endpoint should be considered as adding and deleting | major | | changing endpoint metadata (e.g. description) | patch | | changes to CI | patch | | changes to requirements.txt (and similar) | patch |
🔵 An endpoint is anything specifying some dataset in intake language, e.g.: cat["foo"]["bar"](arg="baz")
would be an endpoint. A notable consequence would be, that adding arguments can be minor if the defaults would result in the same dataset being retrieved if the new arguments are not specified by the user.
❗ We've observed that most of the time a dataset is moved, it's actually deleted from the old location. Because of that, the old version would be broken and thus the new version is significantly different.