2021-02-14 11:27:43 +00:00
|
|
|
# Release instructions
|
|
|
|
|
2024-09-11 10:22:24 +00:00
|
|
|
This documents outlines the frostfs-api release process and can be used as a TODO
|
2021-02-14 11:27:43 +00:00
|
|
|
list for a new release.
|
|
|
|
|
|
|
|
## Pre-release actions
|
|
|
|
|
2024-11-05 13:50:49 +00:00
|
|
|
Increment the milestone version or patch version in case of bug fixes.
|
|
|
|
To add information about compatibility with previous versions of the api for the new code.
|
2022-04-13 06:21:33 +00:00
|
|
|
This must be run:
|
2021-02-14 11:27:43 +00:00
|
|
|
* `make doc`
|
|
|
|
|
2024-11-05 13:50:49 +00:00
|
|
|
## Pre-release checks
|
|
|
|
|
|
|
|
This should run successfully:
|
|
|
|
* `make pre-commit-run`
|
|
|
|
|
2021-02-14 11:27:43 +00:00
|
|
|
## Writing CHANGELOG
|
|
|
|
|
|
|
|
Add an entry to the CHANGELOG.md following the style established there.
|
|
|
|
|
2022-04-13 06:21:33 +00:00
|
|
|
Add a codename for releases with the new major version, version and release date in
|
2021-02-14 11:27:43 +00:00
|
|
|
the heading. Write a paragraph describing the most significant changes done in
|
2022-04-13 06:21:33 +00:00
|
|
|
this release. Then add sections with what has been added, changed and removed,
|
2021-02-14 11:27:43 +00:00
|
|
|
describing each change briefly with a reference to GitHub issues, where
|
|
|
|
available.
|
|
|
|
|
2021-08-16 14:45:23 +00:00
|
|
|
## Release commit
|
|
|
|
|
|
|
|
Release commit summary should follow the template:
|
|
|
|
|
|
|
|
`Release v<Version> - <Codename island> (<Hangeul>, <Hanja>)`, e.g.:
|
|
|
|
|
|
|
|
```
|
2024-11-05 13:50:49 +00:00
|
|
|
Release v3.0 - Anmyeondo (안면도, 安眠島)
|
2021-08-16 14:45:23 +00:00
|
|
|
```
|
|
|
|
|
2021-02-14 11:27:43 +00:00
|
|
|
## Tag the release
|
|
|
|
|
2024-11-05 13:50:49 +00:00
|
|
|
Use `vX.Y` tag (milestone version with patch). For pre-release
|
|
|
|
versions use `vX.Y-rc.N` scheme.
|
2021-02-14 11:27:43 +00:00
|
|
|
|
|
|
|
## Push changes and release tag to Github
|
|
|
|
|
|
|
|
This step should bypass the default PR mechanism to get a correct result (so
|
|
|
|
that releasing requires admin privileges for the project), both the `master`
|
|
|
|
branch update and tag must be pushed simultaneously like this:
|
|
|
|
|
|
|
|
```
|
2024-11-05 13:50:49 +00:00
|
|
|
$ git push origin master v2.7
|
2021-02-14 11:27:43 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
## Make a proper Github release
|
|
|
|
|
|
|
|
Edit an automatically-created release on Github.
|
|
|
|
|
|
|
|
Release title has to follow `<version> <Romanized codename> (<Hangeul, Hanja
|
|
|
|
codename> )` scheme for major releases and just `<version>` for regular point
|
|
|
|
releases.
|
|
|
|
|
|
|
|
## Post-release actions
|
|
|
|
|
2024-11-05 13:50:49 +00:00
|
|
|
* Close corresponding X.Y Github milestone
|
2021-02-14 11:27:43 +00:00
|
|
|
* Make announcements in Matrix and Discord channels
|