We consider the docker image as part of the SonarQube Server product. Therefore, it follows the same release process.
Release of a new version of the official SonarQube Server Docker images is made of several operations. (Please note that in case of a patch release that should not include the latest changes on master, you need to release from a new branch - e.g., release/10.8.1
- and propagate the changes to master afterwards).
- Set the new version of SonarQube Server (
SONARQUBE_VERSION
) to be released in the Dockerfiles. In case of community build, please remember to updatecommunity-build/Dockerfile
only. - If you are releasing a new LTA, set
CURRENT_LTA_VERSION
in.cirrus/tasks.yml
. Otherwise, if you are releasing a Community build, setCOMMUNITY_BUILD_VERSION
only. In all the other cases where a paid edition is about to be releases, setCURRENT_VERSION
(please note that the nightly build will fail before the public image becomes available). - Update the docker hub SonarQube Server's documentation (if applicable)
- Add a GIT tag for the new version
- If you are releasing a SonarQube Server version, you need to Draft a New Release, where the name matches "SonarQube Server 2025.", followed by the month version, i.e., "SonarQube Server 2025.1".
- Likewise, if you are releasing a Community Build, the release name should match "Community Build", followed by the month version, i.e., "Community Build 25.1".
- Update Docker Hub's SonarQube Server images
The version of SonarQube Server is hardcoded in each Dockerfile of this repository and must be updated in master branch.
If needed, prepare PR of Docker Hub documentation https://github.com/docker-library/docs
Note: Please use your own fork like seen in this closed PR
To create a good PR:
- The markdown format must follow a certain standard, otherwise automated tests will fail. You can test with the
markdownfmt.sh
tool included in the repository, for example./markdownfmt.sh -d sonarqube/content.md
will output the diff that would have to be done to make the tests pass. You can use thepatch
command to apply the changes, for example:./markdownfmt.sh -d sonarqube/content.md | patch sonarqube/content.md
- Verify the Pull Request passes the automated tests (visible in the status of the PR)
To control the generated content of the Docker Hub page, look around in the files in .template-helpers
of the [docs
repository][docs]. For example, the "Where to get help" section is customized by a copy of .template-helpers/get-help.md
in sonarqube/get-help.md
.
Until SonarQube Server is released and the public artifacts are available, keep your PR a draft PR to make it clear it is not ready to be merged yet.
For more and up to date documentation, see https://github.com/docker-library/docs.
In order to update the Docker Hub images, a Pull Request must be created on the official-images repository.
To do so you can use your own personal fork.
Create a feature branch on the fork:
GitCommit
must be updated to this repository master branch's HEAD.GitFetch
is the branch/tag (e.g., refs/tags/10.8.1) where the commit can be found. Setting this value is only needed if you are releasing from a branch different from master.Tags
andDirectory
must be added/updated appropriatly for each edition- see https://github.com/docker-library/official-images/pull/8837/files as an example
Until SonarQube Server is released and the public artifacts are available, keep your PR a draft PR to make it clear it is not ready to be merged yet.
- Create the PR here
- If the documentation was updated in the step before, reference that PR in this PR.
- Click on compare across fork to be able to use the fork as head repository.
For more and up to date documentation, see https://github.com/docker-library/official-images.
The commit referenced in the DockerHub Pull Request must be tagged with the (marketing) version of SQ: eg. 8.0
, 8.0.1
, 8.1
.