Release Jenkinsfile: enable manual releases

This commit is contained in:
Yoann Rodière 2024-06-12 11:33:55 +02:00 committed by Christian Beikov
parent 4ac07fc98e
commit 6b004900ca
1 changed files with 31 additions and 17 deletions

View File

@ -40,13 +40,13 @@ pipeline {
string( string(
name: 'RELEASE_VERSION', name: 'RELEASE_VERSION',
defaultValue: '', defaultValue: '',
description: 'The version to be released, e.g. 6.2.1.Final.', description: 'The version to be released, e.g. 6.2.1.Final. Mandatory for manual releases, to prevent mistakes.',
trim: true trim: true
) )
string( string(
name: 'DEVELOPMENT_VERSION', name: 'DEVELOPMENT_VERSION',
defaultValue: '', defaultValue: '',
description: 'The next version to be used after the release, e.g. 6.2.2-SNAPSHOT.', description: 'The next version to be used after the release, e.g. 6.2.2-SNAPSHOT. If not set, determined automatically from the release version.',
trim: true trim: true
) )
booleanParam( booleanParam(
@ -59,39 +59,53 @@ pipeline {
stage('Release check') { stage('Release check') {
steps { steps {
script { script {
// Avoid doing a release for commits from a release
def lastCommitter = sh(script: 'git show -s --format=\'%an\'', returnStdout: true)
def secondLastCommitter = sh(script: 'git show -s --format=\'%an\' HEAD~1', returnStdout: true)
if (lastCommitter == 'Hibernate-CI' && secondLastCommitter == 'Hibernate-CI') {
print "INFO: Build skipped because last commits were for the previous release"
currentBuild.result = 'ABORTED'
return
}
dir('.release/scripts') { dir('.release/scripts') {
checkout scmGit(branches: [[name: '*/main']], extensions: [], userRemoteConfigs: [[credentialsId: 'ed25519.Hibernate-CI.github.com', url: 'https://github.com/hibernate/hibernate-release-scripts.git']]) checkout scmGit(branches: [[name: '*/main']], extensions: [], userRemoteConfigs: [[credentialsId: 'ed25519.Hibernate-CI.github.com', url: 'https://github.com/hibernate/hibernate-release-scripts.git']])
} }
// Determine version information for release process
def manualRelease = currentBuild.getBuildCauses().toString().contains( 'UserIdCause' )
def currentVersion = Version.parseDevelopmentVersion( sh( def currentVersion = Version.parseDevelopmentVersion( sh(
script: ".release/scripts/determine-current-version.sh ${env.PROJECT}", script: ".release/scripts/determine-current-version.sh ${env.PROJECT}",
returnStdout: true returnStdout: true
).trim() ) ).trim() )
echo "Workspace version: ${currentVersion}" echo "Workspace version: ${currentVersion}"
def releaseVersion def releaseVersion
def developmentVersion def developmentVersion
if ( params.RELEASE_VERSION == null || params.RELEASE_VERSION.isEmpty() ) { if ( manualRelease ) {
echo "Release was requested manually"
if ( !params.RELEASE_VERSION ) {
throw new IllegalArgumentException( 'Missing value for parameter RELEASE_VERSION. This parameter must be set explicitly to prevent mistakes.' )
}
releaseVersion = Version.parseReleaseVersion( params.RELEASE_VERSION )
if ( releaseVersion.toString().startsWith( currentVersion.family + '.' ) ) {
throw new IllegalArgumentException( "RELEASE_VERSION = $releaseVersion, which is different from the family of CURRENT_VERSION = $currentVersion. Did you make a mistake?" )
}
}
else {
echo "Release was triggered automatically"
// Avoid doing a release for commits from a release
def lastCommitter = sh(script: 'git show -s --format=\'%an\'', returnStdout: true)
def secondLastCommitter = sh(script: 'git show -s --format=\'%an\' HEAD~1', returnStdout: true)
if (lastCommitter == 'Hibernate-CI' && secondLastCommitter == 'Hibernate-CI') {
print "INFO: Build skipped because last commits were for the previous release"
currentBuild.result = 'ABORTED'
return
}
releaseVersion = Version.parseReleaseVersion( sh( releaseVersion = Version.parseReleaseVersion( sh(
script: ".release/scripts/determine-release-version.sh ${currentVersion}", script: ".release/scripts/determine-release-version.sh ${currentVersion}",
returnStdout: true returnStdout: true
).trim() ) ).trim() )
} }
else {
releaseVersion = Version.parseReleaseVersion( params.RELEASE_VERSION )
}
echo "Release version: ${releaseVersion}" echo "Release version: ${releaseVersion}"
if ( params.DEVELOPMENT_VERSION == null || params.DEVELOPMENT_VERSION.isEmpty() ) { if ( !params.DEVELOPMENT_VERSION ) {
developmentVersion = Version.parseDevelopmentVersion( sh( developmentVersion = Version.parseDevelopmentVersion( sh(
script: ".release/scripts/determine-development-version.sh ${releaseVersion}", script: ".release/scripts/determine-development-version.sh ${releaseVersion}",
returnStdout: true returnStdout: true