-
Notifications
You must be signed in to change notification settings - Fork 17
Release Process
This is a description of the release process. This process can currently be executed by:
- BJ Hargrave @bjhargrave
- Ray Augé @rotty3000
- OSS Nexus Sonatype – The necessary credentials are provisioned as GitHub Secrets in the GitHub repository.
The binary repositories are hosted on OSSRH. We use the Maven groupId org.osgi
.
Repository | Description |
---|---|
released | Released artifacts |
staging | Staged release artifacts |
snapshot | Snapshot artifacts |
All code is stored on GitHub in https://github.com/osgi/osgi-test. The normal development takes place on the main
branch. Changes are merged via PRs. PRs are automatically built with Github Actions for verification but do not release binaries. A commit on main
is automatically released to snapshot
for any successful build. A commit on the release
branch is also released to the staging
repository for a release candidate. Once the staging repo is closed and released, the release artifacts will be available from released
.
This process describes the steps to go from V1 to V2, where V1 and V2 are valid versions with a MAJOR.MINOR.MICRO (no qualifier). For example, V1 could be 1.1.0
. This release process is not an atomic process, it can take a few weeks. During these weeks, a number of release candidates (RCx) are provided for the users to test against.
First, the main
and release
branch are prepared for a release cycle. The main
branch is moved from V1-SNAPSHOT to V2-SNAPSHOT while the release
branch still uses the version V1-SNAPSHOT. The branches are properly tagged and built, this is detailed later in a checklist. Their build output will go to snapshot
but main
will now build a new snapshot version V2-SNAPSHOT
and release
will build the V1-SNAPSHOT
.
During this period fixes are being made on main
. If these fixes are deemed crucial enough to include in the current release cycle then they are cherry picked on release
. In principle, about once every other week a new release candidate is made available for the end users.
Every new RC is properly tagged in git repo from the release
branch with V1.RC1, V1.RC2, etc.
At the big day when the last RCx has been approved, the release
branch is adjusted to not generate a snapshot but an actual release without the SNAPSHOT qualifier. The branch is adjusted to generate V1, tagged and pushed. With the GitHub actions workflow, this will build the release
branch and deploy to staging
. After this release is approved, the releaser will closed and release the staging
which will publish the release artifacts to released
(Maven Central).
Make sure main
is fully committed and it builds properly.
git checkout main
git pull
Set release
branch to state of main
branch.
git branch --force release main
- In
pom.xml
change<revision>V1-SNAPSHOT</revision>
to<revision>V2-SNAPSHOT</revision>
.
Build main
and push:
./mvnw clean install
git add .
git commit -m "build: Start V2 stream"
git push origin main
- Create a new V2 release notes wiki
Release Notes V2
page, e.g. https://github.com/osgi/osgi-test/wiki/Release-Notes-V2. Don't forget to add this to the wiki home page.
Prepare the release
branch.
git checkout release
git tag -s V1.RC1
git push --force origin release V1.RC1
- Verify that that the Wiki release notes are updated.
git shortlog V1.DEV..release --no-merges
where V1.DEV
is the commit which started the V1 stream.
- When there are changes on
main
that should be incorporated on the next release candidate they should be cherry picked ontorelease
.
git checkout release
git cherry-pick ...
git tag -s V1.RCx
git push origin release V1.RCx
- Verify that that the Wiki release notes are updated.
git checkout release
- Remove
-SNAPSHOT
from<revision>V1-SNAPSHOT</revision>
inpom.xml
.
git add .
git commit -m "Release V1"
git tag -s V1
git push origin release V1
After the push, the release will be built and released into the staging
repository.
-
The releaser must then review the
staging
to ensure the release is as expected. If ok, then the releaser must release the staging repository to complete the release process. -
Go to
https://github.com/osgi/osgi-test/releases/tag/V1
and create a GitHub Release for theV1
tag. Set the release title to:OSGi Testing Support V1
and set the description to include a link the the release wiki page
See [Release Notes](https://github.com/osgi/osgi-test/wiki/Release-Notes-V1).
-
Create a new release record for the OSGi Technology Project at Eclipse.