These are the steps to take before you actually cut the release.
These are test cases that we can't test automatically, usually because the intended behavior is
a compiler error. Grep the codebase for uncomment
, and test every such case individually to make
sure they still display the desired behavior.
Create a draft PR which updates Aurora's internal code to the candidate release. Make sure all of the builds pass. If any fail, check whether the best fix lies with Aurora's internal code, or with Au.
GitHub will automatically generate a tarball
of the latest state of main
. The strip_prefix
for this release will typically be
aurora-opensource-au-XXXXXXX
, where XXXXXXX
is the first 7 characters of the most recent commit.
Of course, you can also unpack it (tar -xvzf
) to obtain the strip_prefix
authoritatively.
Set up a compile time measurement using Aurora's internal code as the client code. These measurements should automatically switch back and forth between the previous and new release, and should cover at least a half-dozen Au-dependent targets, ideally diverse ones.
If there is a significant regression, root cause it and see if it can be fixed. If not, mention it in the release notes.
First, go to the latest release. Click the list of "commits to main since this release", found near the top. Read through the commits, and keep track of the main changes as you go. Use the following categories.
- User-facing library changes
- If the compilation speed has been significantly impacted, mention this here.
- New units and constants
- Tooling updates
- Documentation updates
- Repo updates
Any empty section can be omitted.
We try to follow semantic versioning. Since we are currently in major version zero (0.y.z), incompatible changes don't force a major version upgrade.
Edit the CMakeLists.txt
file in the root folder, updating the version number in the project
command to the number chosen above.
Also update the version number in the HOMEPAGE_URL
parameter, because we link to the docs for the
latest release in our CMake project definition. (True, this URL won't exist until you complete the
remaining steps in this guide, but the danger of getting it wrong is pretty small.)
Make a PR with these changes and land it before creating the tag.
The first line should be the tag name.
The second line should be blank.
0.3.1 <--- NOTE: update this!
Release Notes
=============
User-facing library changes
---------------------------
New units and constants
-----------------------
Tooling updates
---------------
Documentation updates
---------------------
Repo updates
------------
Closed Issues
-------------
Here are all of the issues that were closed between these releases. (Note that
the resolution is at the level of days, so some of these issues might show up in
the notes for more than one release.)
NOTE: change dates below!
https://github.com/aurora-opensource/au/issues?q=is%3Aissue+closed%3A2022-12-20..2023-03-18
Contributors
------------
Thanks to those who authored or reviewed PRs, or filed or participated in
Issues! Alphabetically:
- @chiphogg
- ...
First, make sure the "final commit" (which updates the CMake variables) has already landed.
Then, use the command below, replacing 0.3.1
with the version to create.
# Remember to update the tag number!
git tag -a 0.3.1
Copy/paste the above message, and format it as needed. Then, push the tag to GitHub.
# Remember to update the tag number!
git push origin 0.3.1
Manually uploading releases helps future-proof us against previous breakages. See: https://github.blog/2023-02-21-update-on-the-future-stability-of-source-code-archives-and-hashes/
On the tags page, click the .tar.gz
link to
download the tarball.
On the tags page, click the three-dots menu, and select "Create release".
- Use the version number as the title.
- Copy the body of the release notes into the Release Notes text box.
- Attach the tarball downloaded in the previous step.
- Click the
Publish release
button.
First, create the version of the doc website corresponding to this release.
bazel run //:mike -- deploy --push 0.3.1
Next, we need to make sure the manifest for au.hh
and au_noio.hh
on the main
doc website
includes this latest version tag. Check out the main
branch, and run a manual deploy to the
main
doc website:
git checkout main
bazel run //:mike -- deploy --push main