This document describes the current release and versioning strategy. This strategy is likely to change as Rerun matures.
New Rerun versions are released every two weeks. Sometimes we do out-of-schedule patch releases.
Each release include new versions of:
- The Python SDK
- The Rust SDK
- All rust crates
We use semantic versioning. All versions are increased in lockstep, with a minor version bump each time (0.1.0
, 0.2.0
, 0.3.0
, …).
This means we might add breaking changes in each new release.
In rare cases we will do patch releases, e.g. 0.3.1
, when there is a critical bug fix. These patch releases will not contain any breaking changes.
We sometimes do pre-releases. Then we use the versioning 0.2.0-alpha.0
etc.
We have not yet committed to any backwards or forwards compatibility.
We tag all data files (.rrd
files) and communication protocols with the rerun version number. If there is a version mismatch, a warning is logged, but an attempt is still made to load the older or newer data.
Release builds of the Python Wheels are triggered by pushing a release tag to GitHub in the form v0.2.0
.
If we are doing a patch release, we do a branch off of the latest release tag (e.g. v0.3.0
) and cherry-pick any fixes we want into that branch.
Go through this checklist from top to bottom, and check each item before moving onto the next. This is a living document. Strive to improve it on each new release.
- Create a release branch called
release-0.x
- If it is a patch release, continue off the existing
release-0.x
branch and cherry-pick the additional commits that should be included - Update
CHANGELOG.md
with the new version number with:- A one-line summary of the release
- A multi-line summary of the release
- A gif showing a major new feature
- Run
git tag -d latest && git fetch --tags ; pip install GitPython && scripts/generate_changelog.py
- Edit PR descriptions/labels to improve the generated changelog
- Copy-paste the results into
CHANGELOG.md
. - Editorialize the changelog if necessary
- Make sure the changelog includes instructions for handling any breaking changes
- Commit and push the changelog
- Check that the
rerun-docs
are up to date:- Python quick start
- Logging Data in Python
- Rust quick start
- Logging Data in Rust
- Create a draft PR containing:
- One-line summary of the release
- A multi-line summary of the release
- A gif showing a major new feature
- Test the branch (see below)
- Open the PR up for review with the
⛴ release
label - Bump version number in root
Cargo.toml
. - Check that CI is green
- Publish the crates (see below)
- Manually run the workflow to create the python wheels and web artifacts for the
release-0.x
branch.- https://github.com/rerun-io/rerun/actions/workflows/manual_build_release.yml
- Choose the release branch, and enter the release number
0.x.y
or0.x.y-alpha.z
.
- Verify the build wheels and web artifacts look correct.
- For the final release, manually run the workflow to publish the artifacts to pypi and create the GitHub release.
- https://github.com/rerun-io/rerun/actions/workflows/manual_release.yml
- Choose the release branch, and enter the release number
0.x.y
- This will create the GitHub release page in draft state.
- Publishing this release will create the release tag
- Edit the GitHub draft release at https://github.com/rerun-io/rerun/releases
- Mark it as as the latest release
- Paste in the
CHANGELOG.md
-
git pull --tags && git tag -d latest && git tag -a latest -m 'Latest release' && git push --tags origin latest --force
- Wait for documentation to build: https://docs.rs/releases/queue
- Point https://app.rerun.io/ to the latest release via instructions in https://www.notion.so/rerunio/Ops-Notes-9232e436b80548a2b252c2312b4e4db6?pvs=4.
- Post on:
- Community Discord
- Rerun Twitter
- Reddit?
Before pushing the release tag:
-
just py-run-all
- Test the web viewer:
-
just py-run-all --fast --parallel --web
- Test on:
- Chromium
- Firefox
- Mobile
-
After tagging and the CI has published:
- Test the Python packages from PyPI:
pip install rerun_sdk==0.x.0a1
- Test rust install version:
cargo install --force [email protected] && rerun --web-viewer api.rrd
- Test rust crate: Modify Cargo.toml of any example to not point to the workspace
- run with
--serve
to test web player
- run with
Checklist for testing alpha releases:
- Windows
- Python Wheel
- Web
- Native
- Rust crate
- Web
- Native
- Rust install
- Web
- Native
- Python Wheel
- Linux
- Python Wheel
- Web
- Native
- Rust crate
- Web
- Native
- Rust install
- Web
- Native
- Python Wheel
- Mac
- Python Wheel
- Web
- Native
- Rust crate
- Web
- Native
- Rust install
- Web
- Native
- Python Wheel
First login as https://crates.io/users/rerunio with and API key you get from Emil:
cargo login $API_KEY
!! IMPORTANT !! Shut off VSCode, and don't touch anything while publish_crates.sh
is running!
!! IMPORTANT !! Read publish_crates.sh
for details
./scripts/publish_crates.sh --execute