Automated Release
This article provides the details on performing a release by the release manager.
Release All Projects
The Publish: Release All is a GitHub workflow that will release all the PASS projects in the correct order, build and push docker images, and create GitHub Releases. The Publish: Release All
requires GitHub PAT configuration.
The Publish: Release All
workflow is the preferred method of doing a PASS release. If for some reason, a PASS release needs to be done one project at a time, follow the steps in Release Projects One At a Time section.
Release Projects One At a Time
Java projects
The Publish: release all Java modules combines all the Java projects together and then releases them in one single workflow. The Publish: release all Java modules
requires GitHub PAT configuration. See GitHub Personal Access Token Setup.
If needed, the individual Java components can be released individually. Release these in the order defined here due to dependencies. Between each of these releases, you will need to wait for the Java artifacts to appear on Maven Central. This will give you enough time to do other release activities, such as releasing non-Java artifacts. The release workflows should wait for you, but checking will mitigate any potential issues with the release.
Non-Java projects
These can be released in any order. You should release these between releasing Java components, while waiting for artifacts to become available in Maven Central.
Other projects
This must be released last because it relies on some of the Docker images that will be published during the release process of the preceding projects.
GitHub code release
You will have to manually create a GitHub release through the GitHub web interface to complete the release of each of these components. This can generally be done any time after the release automation completes successfully, since the release will be made against a tag created by the automation.
Navigate to the Releases section of the repository.
Click the "Draft new release" button near the top of the page.
Input release title, matching the release version used for the release (e.g. 0.5.0).
Choose the release tag that was created during the automation.
Click on the "Generate release notes" button to generate a list of changes since the last release.
Triggering a GitHub workflow
Take eclipse-pass/main as an example.
Navigate to the
Actions
tab in your target repository. Select the workflow you want to trigger, e.g. the Release workflow in Publish: Release AllClick on the
Run workflow
buttonInput the branch you wish to run the release against and the desired
Release
andNext dev
versionsRelease version: full release version, e.g. 1.10.0. These versions should be regarded as immutable. These releases for Java projects cannot be updated or deleted.
Next development version: snapshot or development versions, e.g. 1.11.0-SNAPSHOT (please use all capital letters for the SNAPSHOT suffix). These development versions are intended to be overwritten.
After a few seconds, a new workflow run should appear in the table with a yellow (in-progress) status dot. Clicking on that will allow you to monitor the run's progress by watching logs.
It is recommended that you monitor the automation after triggering it to make sure it completes successfully before moving on to release the next component.
GitHub Personal Access Token Setup
Some GitHub workflows depend on the JAVA_RELEASE_PAT
secret having permission to access all the eclipse-pass repositories and write packages. You have to create a new classic Personal Access Token (PAT) to do the release (GitHub/Settings/Developer Settings/Personal access tokens/Tokens (classic)). If you do so, set the expiration to 7 days, check the repo
and the write:packages
scope (subscopes under repo
and write:packages
will be selected too).
How to set the secret in the main repository using the gh command line tool GitHub CLI:
Last updated