Release Process
Bevy uses three-months-long development cycles, delimited by a weeks-long rolling release process.
This means that Bevy releases a new version roughly once every three to four months. In an effort to avoid crunch and encourage sustainable development, we do not pick specific dates or deadlines.
Development Cycles
During a three-month development cycle, Maintainers collect important PRs and issues into a GitHub Milestone. Issues included in the milestone are given priority, and the community generally makes a best-effort attempt to merge as many of these as possible over the duration of the cycle.
In the lead-up to a release (generally about two and a half months after the previous) we begin to aggressively purge the milestone of things that seem unlikely to be ready in time. The main things that tend to remain are:
- Quick and easy features under active development.
- Fixes for important regressions or crashes.
- Large or impressive features that only need minor polish.
When the milestone is complete, we open a new working group to handle the release preparations, publish a release candidate (ex. 0.14.0-rc.1
) and begin the release process.
Release Candidates
In the run-up to a release, Bevy publishes a new release candidate about once a week. Publishing release candidates allows users to identify bugs and regressions, gives ecosystem crates time to update so they can be ready closer to release day, and provides Bevy contributors extra time to write release notes and migration guides.
When publishing a release candidate, we also announce a general target release date. This is generally about one week out. If critical bugs or regressions are discovered during this testing window, we fix them and publish a new release candidate. Then we either
- Announce a new date, if we believe more testing time is needed than the current window, or
- Keep the same target release date if we believe there is enough time in the current window.
When we successfully hit a release candidate's target date, we do the final release.
Release Checklist
When making a release, the Maintainers follow these checklists:
Minor Version
Minor Pre-release
- Check regressions tag.
- Check appropriate milestone and close it.
- Check GitHub Projects page for staleness.
- Update change log.
- Create migration guide.
- Write blog post.
- Update book.
- Bump version number for all crates, using the "Release" workflow.
- Change the commit message to be nicer.
- Create tag on GitHub.
- Edit GitHub Release. Add links to the
Release announcement
andMigration Guide
. - Bump
latest
tag to most recent release. - Run the
update-screenshots
workflow to update screenshots. This will block blog post releases (and take ~40 minutes) so do it early. - Run the
build-wasm-examples
workflow to update Wasm examples.
Minor Release
- Release on crates.io using
bash tools/publish.sh
- Announce on:
- HackerNews
- Reddit: /r/bevy, /r/rust, /r/rust_gamedev
- Discord: Bevy, Game Development in Rust, Rust Programming Language Community
- This Month in Rust Game Development newsletter
- This Week in Rust newsletter
Minor Post-release
- Bump version number for all crates to next versions, as
0.X-dev
, using the "Post-release version bump" workflow, to ensure properly displayed version for Dev Docs. - Update Bevy version used for Bevy's website's
learning-code-examples
tool (code example validation and formatting for the learning materials) to latest release.
Patch
Patch Pre-release
- Check appropriate milestone.
- Close the milestone, open the next one if anything remains and transfer them.
- Create a new branch
release-0.X.Y
from thelatest
tag, and cherry pick all PRs from the milestone to the new branch
version="0.X.Y"
git checkout latest
git checkout -b release-$version
echo
prs=`gh pr list --repo bevyengine/bevy --search "milestone:$version" --state merged --json mergeCommit,mergedAt,title,number`
while read -r commit number title <&3; do
echo "PR #$number: $title (https://github.com/bevyengine/bevy/pull/$number)"
if git cherry-pick $commit; then
echo
else
echo "please resolve conflict then press enter"
read
fi
done 3<<(echo $prs | jq --raw-output '. |= sort_by(.mergedAt) | .[] | "\(.mergeCommit.oid) \(.number) \(.title)"')
- Bump version number for all crates, using the command from the "Release" workflow locally, with
patch
for the new version.- Change the commit message to be nicer:
git commit --amend -m "Release 0.X.Y
- Change the commit message to be nicer:
- Create tag on GitHub.
- Edit GitHub Release. Add link to the comparison between this patch and the previous version.
- Bump
latest
tag to most recent release. - Run the
update-screenshots
workflow to update screenshots. - Run this
build-wasm-examples
workflow to update Wasm examples.
Patch Release
- Release on crates.io
bash tools/publish.sh
- Announce on:
- Discord: Bevy, #announcements
Patch Post-Release
Release Candidate
RC Pre-Release
- Check appropriate milestone.
- Create a branch for the release.
- Bump version number for all crates, using the command from the "Release" workflow locally, with
rc
for the new version.- Change the commit message to be nicer.
- Create tag on GitHub.
- Edit GitHub Release. Add link to the comparison between this release candidate (rc) and the previous version.
RC Release
- Release on crates.io
bash tools/publish.sh
- Announce on:
- Discord: Bevy, #dev-announcements
RC Post-Release
- Update Bevy version used for Bevy's website's
learning-code-examples
tool (code example validation and formatting for the learning materials) to latest release.