Skip to content

Latest commit

 

History

History
165 lines (110 loc) · 4.99 KB

RELEASE.md

File metadata and controls

165 lines (110 loc) · 4.99 KB

How to cut a new release

Preparing the release

These are the steps to take before you actually cut the release.

Check all commented-out test cases

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.

Check Aurora's code

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.

Check cumulative compile time impact

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.

Gather information for 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.

Cutting the release

Pick a version number

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.

Update the CMake version number

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.

Fill out release notes template

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
- ...

Create the tag

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

Upload the artifact

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.

Create the release

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.

Regenerate the doc website

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