- Run the Prepare release branch workflow.
- Press the "Run workflow" button, and leave the default branch
main
selected.- If making a pre-release of stable components (e.g. release candidate),
enter the pre-release version number, e.g.
1.9.0rc2
. (otherwise the workflow will pick up the version frommain
and just remove the.dev
suffix).
- If making a pre-release of stable components (e.g. release candidate),
enter the pre-release version number, e.g.
- Review the two pull requests that it creates.
(one is targeted to the release branch and one is targeted to
main
).- The builds will fail for both the
main
and release pr because of validation rules. Follow the release workflow for the core repo up until this same point. Change the SHAs of each PR to point at each other to get themain
and release builds to pass.
- The builds will fail for both the
- Merge the release PR.
- Merge the PR to main (this can be done separately from making the release)
- Press the "Run workflow" button, and leave the default branch
Note
Per-package release is supported for the following packages only:
- opentelemetry-propagator-aws-xray
- opentelemetry-resource-detector-azure
- opentelemetry-sdk-extension-aws
- opentelemetry-instrumentation-openai-v2
These libraries are also excluded from the general release.
Package release preparation is handled by the [Package] Prepare release
workflow that allows
to pick a specific package to release. It follows the same versioning strategy and process as the general release.
Long-term package release branch follows package-release/{package-name}/v{major}.{minor}.x
(or package-release/{package-name}/v{major}.{minor}bx
) naming pattern.
The workflow will create two pull requests, one against the main
and one against the package-release/
branch; both should be merged in order to proceed with the release.
- Backport pull request(s) to the release branch.
- Run the Backport workflow.
- Press the "Run workflow" button, then select the release branch from the dropdown list,
e.g.
release/v1.9.x
, then enter the pull request number that you want to backport, then click the "Run workflow" button below that. - Review and merge the backport pull request that it generates.
- Merge a pull request to the release branch updating the
CHANGELOG.md
.- The heading for the unreleased entries should be
## Unreleased
.
- The heading for the unreleased entries should be
- Run the Prepare patch release workflow.
- Press the "Run workflow" button, then select the release branch from the dropdown list,
e.g.
release/v1.9.x
, and click the "Run workflow" button below that. - Review and merge the pull request that it creates for updating the version.
- Press the "Run workflow" button, then select the release branch from the dropdown list,
e.g.
Note
Per-package release is supported only for packages included in the corresponding workflow. Libraries that support per-package release are currently excluded from the general patch release.
Per-package patch release preparation is handled by the [Package] Prepare patch release
workflow that allows
to pick a specific package to release.
The workflow can only be run against long-term release branch such as package-release/{package-name}/v{major}.{minor}.x
or package-release/{package-name}/v{major}.{minor}bx
.
The workflow will create a pull request that should be merged in order to proceed with the release.
- Run the Release workflow.
- Press the "Run workflow" button, then select the release branch from the dropdown list,
e.g.
release/v1.9.x
, and click the "Run workflow" button below that. - This workflow will publish the artifacts and publish a GitHub release with release notes based on the change log.
- Review and merge the pull request that it creates for updating the change log in main (note that if this is not a patch release then the change log on main may already be up-to-date, in which case no pull request will be created).
- Verify that a new Github release has been created and that the CHANGELOGs look correct.
- Press the "Run workflow" button, then select the release branch from the dropdown list,
e.g.
Note
Per-package patch release is supported for the following packages only:
- opentelemetry-propagator-aws-xray
- opentelemetry-resource-detector-azure
- opentelemetry-sdk-extension-aws
- opentelemetry-instrumentation-openai-v2
These libraries are also excluded from the general patch release.
Per-package release is handled by the [Package] Release
workflow that allows
to pick a specific package to release.
The workflow can only be run against long-term release branch such as package-release/{package-name}/v{major}.{minor}.x
or package-release/{package-name}/v{major}.{minor}bx
.
- Check PyPI
- This should be handled automatically on release by the publish action.
- Check the action logs to make sure packages have been uploaded to PyPI
- Check the release history (e.g. https://pypi.org/project/opentelemetry-instrumentation/#history) on PyPI
- If for some reason the action failed, see Publish failed below
- The version number for stable components in the
main
branch is alwaysX.Y.0.dev
, whereX.Y.0
represents the next minor release. - When the release branch is created, you can opt to make a "pre-release", e.g.
X.Y.0rc2
. - If you ARE NOT making a "pre-release":
- A "long-term" release branch will be created, e.g.
release/v1.9.x-0.21bx
(notice the wildcard x's). Later on, after the initial release, you can backport PRs to a "long-term" release branch and make patch releases from it. - The version number for stable components in the release branch will be bumped to remove the
.dev
, e.g.X.Y.0
. - The version number for stable components in the
main
branch will be bumped to the next version, e.g.X.{Y+1}.0.dev
.
- A "long-term" release branch will be created, e.g.
- If you ARE making a "pre-release":
- A "short-term" release branch will be created, e.g.
release/v1.9.0rc2-0.21b0
(notice the precise version with no wildcard x's). "Short-term" release branches do not support backports or patch releases after the initial release. - The version number for stable components in the
main
branch will not be bumped, e.g. it will remainX.Y.0.dev
since the next minor release will still beX.Y.0
.
- A "short-term" release branch will be created, e.g.
- The version number for unstable components in the
main
branch is always0.Yb0.dev
, where0.Yb0
represents the next minor release.- Question: Is "b" (beta) redundant on "0." releases, or is this a python thing? I'm wondering if we can change it to
0.Y.0
to match up with the practice in js and go repos.
- Question: Is "b" (beta) redundant on "0." releases, or is this a python thing? I'm wondering if we can change it to
- Unstable components do not need "pre-releases", and so whether or not you are making a "pre-release" of stable
components:
- The version number for unstable components in the release branch will be bumped to remove the
.dev
, e.g.0.Yb0
. - The version number for unstable components in the
main
branch will be bumped to the next version, e.g.0.{Y+1}b0.dev
.
- The version number for unstable components in the release branch will be bumped to remove the
When a contribution introduces a new package, in order to mitigate name-squatting incidents, release the current development version of the new package under the opentelemetry
user to simply claim the namespace. This should be done shortly after the PR that introduced this package has been merged into main
.
If for some reason the action failed, do it manually:
- Switch to the release branch (important so we don't publish packages with "dev" versions)
- Build distributions with
./scripts/build.sh
- Delete distributions we don't want to push (e.g.
testutil
) - Push to PyPI as
twine upload --skip-existing --verbose dist/*
- Double check PyPI!