diff --git a/RELEASES.md b/RELEASES.md index 173b75902..fc4f77d3f 100644 --- a/RELEASES.md +++ b/RELEASES.md @@ -3,22 +3,33 @@ This document explains the release procedure. It is only relevant for maintainers. -## 1. Write release announcement +## 1. Install/update automation tool + +We have a CLI tool to automate parts of the release process. Make sure you have the latest version of that installed. + +In the Fornjot repository, run: +``` sh +cargo install --path tools/automator +``` + + +## 2. Write release announcement The release announcement lives on the website, and needs to be created in the [website repository](https://github.com/hannobraun/www.fornjot.app). First, create the initial draft of the release announcement (replace date with date of previous release; replace version with version of the new release): ``` -cargo run -- create-release-announcement 2022-08-08 0.12.0 +automator create-release-announcement 2022-08-22 0.13.0 ``` This will create an announcement that will initially not be published to the blog or RSS feed, but it will be available at its final URL. Now, edit this file to finish the release announcement: -1. Go through all pull requests, add them to the draft. - - Links for the relevant pull requests have already been added. +1. Add pull requests + - A list of pull requests has been added to the draft automatically. + Go through them, update and merge entries as appropriate, sort them into the correct categories. - Thank all contributors - new contributors: "special thanks go to first-time contributor `@name`!" - other contributors: "thank you, `@name`!" @@ -44,8 +55,14 @@ Potential new issues of the week: - https://github.com/hannobraun/Fornjot/issues/794 - https://github.com/hannobraun/Fornjot/issues/805 - https://github.com/hannobraun/Fornjot/issues/848 +- https://github.com/hannobraun/Fornjot/issues/971 +- https://github.com/hannobraun/Fornjot/issues/986 +- https://github.com/hannobraun/Fornjot/issues/987 +- https://github.com/hannobraun/Fornjot/issues/996 +- https://github.com/hannobraun/Fornjot/issues/997 Already mentioned issues of the week (remove, once closed): +- 2022-08-29: https://github.com/hannobraun/Fornjot/issues/980 - 2022-08-22: https://github.com/hannobraun/Fornjot/issues/938 - 2022-08-08: https://github.com/hannobraun/Fornjot/issues/20 - 2022-08-01: https://github.com/hannobraun/Fornjot/issues/883 @@ -54,7 +71,7 @@ Already mentioned issues of the week (remove, once closed): - 2022-07-04: https://github.com/hannobraun/Fornjot/issues/479 -## 2. Create release branch +## 3. Create release branch In the main Fornjot repository, do this: @@ -62,51 +79,57 @@ In the main Fornjot repository, do this: git switch -c release ``` -## 3. Update changelog +## 4. Update changelog Add a changelog entry for the new version. Copy the summary of pull requests from the release announcements and add it to the changelog. Commit these changes: `git commit -m "Update changelog"` -## 4. Update version +## 5. Update version In the release branch, update the version numbers in the `Cargo.toml` files of all crates in the `crates/` directory to the new version. Also update the version numbers of the dependencies between the crates. Commit these changes: `git commit -m "Update version"` -## 5. Publish the release +## 6. Publish the release + +Push the release branch: +``` sh +git push -u origin release +``` -Push the release branch, create a pull request, and label it as `release`. Once the CI build completed successfully, merge the pull-request and mention the new version in the commit, e.g. `Release v0.1.2`. +Create a pull request, mention the release in the title (e.g. `Release v0.1.2`), and label it as `release`. -The [release-operator](./tools/release-operator) will run in the scope of GitHub Actions' [CD](./.github/workflows/cd.yml) workflow. It will yield a set of compiled binaries, their checksums and a new GitHub Release with all artifacts attached. +- Once the CI build completed successfully, merge the pull request. +- After merging, lock the pull requests. Anything that updates this pull request (like comments), could confuse next week's release automation (because GitHub doesn't allow fetching pull requests by merged date, unfortunately). -It will also `cargo publish` all crates to [crates.io](https://crates.io/). +The release automation will now compile binaries, create a release on GitHub, and publish to [crates.io](https://crates.io/). -## 6. Update release on GitHub +## 7. Update release on GitHub The GitHub Release has been created by automation in the previous step. Copy the Markdown source from the release announcement into the GitHub release. Update as necessary. Add note up top, linking to the release announcement on the website. -## 7. Finish publishing release announcement +## 8. Finish publishing release announcement To publish the release on the website properly, add a `date` key to the front matter. Now the announcement should show up on the blog page and the Atom/RSS feed. Deploy the announcement to the website. -## 8. Promote release announcement +## 9. Promote release announcement -Post the release announcement in the official Fornjot channels: +Post the release announcement in the official Fornjot community channels: - Mailing list - Matrix channel -Post it in the following channels: +Additionally, post it in the following communities: - Reddit - https://www.reddit.com/r/rust/ @@ -119,6 +142,6 @@ Post it in the following channels: https://github.com/rust-lang/this-week-in-rust -## 9. Improve release procedure +## 10. Improve release procedure You are done. Figure out what didn't go optimally, and update this release procedure accordingly.