Context
The 0.42.0 release process (#678) exposed several manual steps and gaps in our release tooling. While the current scripts/apache_release.py handles the basics (build, sign, SVN upload, vote template), there is no automation for RC promotion, release branches, backports, reproducible builds, or release notes.
Looking at how other Apache projects (especially Airflow) handle releases, there are clear improvements we can adopt to make the process more reliable and less error-prone.
Current state
scripts/apache_release.py handles build, GPG signing, SHA-512 checksums, and SVN upload
scripts/verify_apache_artifacts.py handles voter verification
- Vote email template is generated but sent manually
- RC promotion from
dist/dev to dist/release is fully manual
- No release branches, no backport automation, no reproducible builds
Goals
- Make cutting an RC a single-command operation
- Make promoting a passed RC to final release a single-command operation
- Introduce release branches for safe cherry-picking during vote periods
- Automate release notes generation
- Ensure builds are reproducible (bit-for-bit identical from same source)
Sub-issues
Context
The 0.42.0 release process (#678) exposed several manual steps and gaps in our release tooling. While the current
scripts/apache_release.pyhandles the basics (build, sign, SVN upload, vote template), there is no automation for RC promotion, release branches, backports, reproducible builds, or release notes.Looking at how other Apache projects (especially Airflow) handle releases, there are clear improvements we can adopt to make the process more reliable and less error-prone.
Current state
scripts/apache_release.pyhandles build, GPG signing, SHA-512 checksums, and SVN uploadscripts/verify_apache_artifacts.pyhandles voter verificationdist/devtodist/releaseis fully manualGoals
Sub-issues
SOURCE_DATE_EPOCHvX.Y-test+vX.Y-stable)