Skip to content
This repository has been archived by the owner on Nov 10, 2021. It is now read-only.

Latest commit

 

History

History
41 lines (25 loc) · 1.61 KB

RELEASE_GUIDE.md

File metadata and controls

41 lines (25 loc) · 1.61 KB

Publishing a new release

  1. Set the environment variable TAG, which should be of the form v{VERSION}, where VERSION is the target version of the release.

  2. Change version in all subcrate Cargo.toml files and in the root Cargo.toml to the target version. Also change the version of the subcrate dependencies in the root Cargo.toml. All versions should now match the target version.

  3. Update the CHANGELOG by creating a new release section header right the ## Unreleased header.

  4. Commit and push these changes:

    git commit -a -m "(cargo-release) $TAG" && git push
  5. Add a tag in git to mark the release:

    git tag "$TAG" -m "Adds tag $TAG for release" && git push --tags
  6. Find the tag you just pushed on GitHub, click edit, then copy over the output of:

    python scripts/generate_release_notes.py
    

    On a Mac, for example, you can just pipe the above command into pbcopy.

  7. Check the box "This is a pre-release" if the release is a release candidate (ending with -rc*). Otherwise leave it unchecked.

  8. Finally, click "Publish Release". GitHub Actions will then build and publish to crates.io.

Fixing a failed release

If for some reason the GitHub Actions release workflow failed with an error that needs to be fixed, you'll have to delete both the tag and corresponding release from GitHub. After you've pushed a fix, delete the tag from your local clone with

git tag -l | xargs git tag -d && git fetch -t

Then repeat the steps above.