This page describes how to mechanically make releases of DiracX and extensions. See the reference documentation for more details about how releases are made.
How to make a new DiracX release
-
Merge any PR you want in your release
-
Find the
release-pleasepull request for your release -
Review the release number and the content of the changelog
- If you need to change the release number, follow the
release-pleasedoc
git commit --allow-empty -m "chore: release 0.0.3" -m "Release-As: v0.0.3" git push upstream HEAD:main- TODO: update the release notes manually
- If you need to change the release number, follow the
-
Merge the PR
-
Check the deployment action
-
Check that the CI in
diracx-chartsis successful
At this stage, there is a new diracx and diracx-chart release.
Making the extension release
Making a release of an extension depends on how the extension has been set up. Below are recommended workflows:
- Ensure any desired merge requests have been merged.
- Ensure the
pyproject.tomlcontains the desired DiracX dependency- If it does not, run the pipeline schedule to run renovate, which should trigger a merge request to update the version.
- Merge the renovate-generated MR.
- Create tag (and optionally release) for your extension
- Updates to extension's "charts" repo will be pushed automatically or via merge requests depending on your setup.
- The LHCb installation follows the "Generic GitLab" workflow.
- The renovate job runs every Monday at 22:10 UTC. It can be manually triggered here.
- The LHCb certification set up is updated automatically, see here for the pipelines.
- The LHCb production setup is deployed automatically when the associated merge request is merged. See here for the pending updates.