Self releases are now possible after the migration to latest global-jjbs staging jobs
gerrit-maven-stage and gerrit-maven-docker-stage
Currently Maven2 JAR artifacts self release process is finalized. Docker Images self releases
is still under construction.
Before teams start using self releases ...
Please note that this process will be possible by committers with Merge/+2 Rights in the repos.
Please make sure your INFO.yaml files are updated and that all committers have been added.
More information of these procedure can be found here. (Please make sure to read this and ask any
questions to support.linuxfoundation.org:
https://github.com/lfit/releng-global-jjb/blob/master/docs/jjb/lf-release-jobs.rst
How does it work?
The process is very simple. It will require for tech teams to post a new "releases" folder with a yaml file for each release
they need. This file gets verified and, once merged, the release will be posted.
Here are the steps:
- The tech team needs to make sure their committer list is up to date as these will be the people approved to make releases.
- The reason behind this, only committers can +2 and merge changes in their tech team repo.
- The releases merge job will be triggered by files merged in the repo and will execute a release.
- Tech team needs to add "{project-name}-gerrit-release-jobs" to their ci-management yaml files.
- This group introduces "gerrit-release-verify" and "gerrit-release-merge"
- Once a release candidate is build using gerrit-maven-stage, a new file will be posted describing the release.
- This file needs to be located in the root repo under a "releases" folder.
- An example can be viewed here: https://github.com/lfit/releng-global-jjb/blob/master/docs/jjb/lf-release-jobs.rst
- Name of the file should match the semantic version of the release being publihed. (For example: releases/1.0.0.yaml)
- distribution_type: 'maven' (Future expansion will allow "container" to be provided"
- version: '#.#.#' (Release semantic version)
- project: 'project-name' (Project name, for example 'ccsdk-parent')
- log-dir: 'pointer_to_maven_stage_job/build_number/' (for example: 'ccsdk-parent-maven-stage-master/2/')
- maven_central_url: 'oss.sonatype.org' ( Optional, in case the team want's to publish to Maven Central)
- This file will trigger "{project-name}-release-verify-{stream}"
- This job can also be triggered using the comment "recheck|reverify"
- The verify job will make sure the release file contains the needed information and that the candidate exists.
- Tech team needs to +2 this new change and merge it. Please do not override any -1 Verify from Jenkins.
- The merge will trigger "{project-name}-release-merge-{stream}"
- This job can also be triggered using the comment "remerge"
- This job will push the release and tag the repo.