-
Notifications
You must be signed in to change notification settings - Fork 1
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
* add RELEASING.md * adjust indentation * add release notes to documentation * [pre-commit.ci] auto fixes from pre-commit.com hooks for more information, see https://pre-commit.ci * fix copy paste mistake * fix another oopsie * tweak shade thrown at SemVer projects * add another wording tweak * another tweak * last tweak i promise * okay, i lied * can't stop won't stop * drunk with editing power * okay, last one I SWEAR * can't stop lying and can't stop editing --------- Co-authored-by: pre-commit-ci[bot] <66853113+pre-commit-ci[bot]@users.noreply.github.com>
- Loading branch information
1 parent
9e62d04
commit afab0b4
Showing
6 changed files
with
89 additions
and
5 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
# Releasing a New Version | ||
|
||
When it comes time to cut a new release, follow these steps: | ||
|
||
1. Create a new git branch off of `main` for the release. | ||
|
||
Prefer the convention `release-<version>`, where `<version>` is the next incremental version number (e.g. `release-v1.0.0` for version 1.0.0). | ||
|
||
```shell | ||
git checkout -b release-v<version> | ||
``` | ||
|
||
However, the branch name is not *super* important, as long as it is not `main`. | ||
|
||
2. Update the version number across the project using the `bumpver` tool. See [this section](#choosing-the-next-version-number) for more details about choosing the correct version number. | ||
|
||
The `pyproject.toml` in the base of the repository contains a `[tool.bumpver]` section that configures the `bumpver` tool to update the version number wherever it needs to be updated and to create a commit with the appropriate commit message. | ||
|
||
If you have not already installed `bumpver`, you can install it with: | ||
|
||
```shell | ||
python -m pip install bumpver | ||
``` | ||
|
||
Then, run `bumpver` to update the version number, with the appropriate command line arguments. See the [`bumpver` documentation](https://github.com/mbarkhau/bumpver) for more details. | ||
|
||
**Note**: For any of the following commands, you can add the command line flag `--dry` to preview the changes without actually making the changes. | ||
|
||
Here are the most common commands you will need to run: | ||
|
||
```shell | ||
bumpver update --patch # for a patch release | ||
bumpver update --minor # for a minor release | ||
bumpver update --major # for a major release | ||
``` | ||
|
||
To release a tagged version, such as a beta or release candidate, you can run: | ||
|
||
```shell | ||
bumpver update --tag=beta | ||
# or | ||
bumpver update --tag=rc | ||
``` | ||
|
||
Running these commands on a tagged version will increment the tag appropriately, but will not increment the version number. | ||
|
||
To go from a tagged release to a full release, you can run: | ||
|
||
```shell | ||
bumpver update --tag=final | ||
``` | ||
|
||
3. Ensure the [CHANGELOG](https://github.com/westerveltco/django-email-relay/blob/main/CHANGELOG.md) is up to date. If updates are needed, add them now in the release branch. | ||
|
||
4. Create a pull request from the release branch to `main`. | ||
|
||
5. Once CI has passed and all the checks are green ✅, merge the pull request. | ||
|
||
6. Draft a [new release](https://github.com/westerveltco/django-email-relay/releases/new) on GitHub. | ||
|
||
Use the version number with a leading `v` as the tag name (e.g. `v1.0.0`). | ||
|
||
Allow GitHub to generate the release title and release notes, using the 'Generate release notes' button above the text box. If this is a final release coming from a tagged release (or multiple tagged releases), make sure to copy the release notes from the previous tagged release(s) to the new release notes (after the release notes already generated for this final release). | ||
|
||
If this is a tagged release, make sure to check the 'Set as a pre-release' checkbox. | ||
|
||
7. Once you are satisfied with the release, publish the release. As part of the publication process, GitHub Actions will automatically publish the new version of the package to PyPI and the new version of the Docker image to GitHub Container Registry. | ||
|
||
## Choosing the Next Version Number | ||
|
||
We try our best to adhere to [Semantic Versioning](https://semver.org/), but we do not promise to follow it perfectly (and let's be honest, this is the case with a lot of projects using SemVer). | ||
|
||
In general, use your best judgement when choosing the next version number. If you are unsure, you can always ask for a second opinion from another contributor. | ||
|
||
As outlined in our [deprecation policy](https://django-email-relay.westervelt.dev/en/latest/updating.html#deprecation-policy), any release that involves a change to models, and thus has migrations associated with the release, **MUST** be a major release. If this is so, ensure that the changes were first introduced in a backwards compatible way with deprecation warnings in a minor release first before introducing the backwards incompatible changes in a major release. |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,9 @@ | ||
```{include} ../../CONTRIBUTING.md | ||
``` | ||
|
||
```{toctree} | ||
:hidden: | ||
releasing | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
```{include} ../../RELEASING.md | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -13,5 +13,5 @@ installation/index | |
usage/index | ||
configuration/index | ||
updating | ||
contributing | ||
contributing/index | ||
``` |