From 9a378d84b1211fa39c67ba43b43c2f6fbaa30a95 Mon Sep 17 00:00:00 2001 From: Rodrigo Antunes Date: Fri, 26 Jul 2024 10:10:58 -0300 Subject: [PATCH 1/7] [10.0.x] kie-issues#1397: Adjust release pipelines for the Apache 10 release (#3111) * Adjust release pipelines for the Apache 10 release * Adjust release pipelines for the Apache 10 release --- .ci/jenkins/Jenkinsfile.deploy | 59 ++++++++++----- .ci/jenkins/dsl/jobs.groovy | 11 +-- .ci/jenkins/project/Jenkinsfile.release | 97 ++++--------------------- 3 files changed, 59 insertions(+), 108 deletions(-) diff --git a/.ci/jenkins/Jenkinsfile.deploy b/.ci/jenkins/Jenkinsfile.deploy index 4e30c0c3d5c..771331d5692 100644 --- a/.ci/jenkins/Jenkinsfile.deploy +++ b/.ci/jenkins/Jenkinsfile.deploy @@ -35,7 +35,7 @@ imageUtils = null pipeline { agent { - docker { + docker { image env.AGENT_DOCKER_BUILDER_IMAGE args env.AGENT_DOCKER_BUILDER_ARGS label util.avoidFaultyNodes() @@ -52,7 +52,6 @@ pipeline { OPTAPLANNER_CI_EMAIL_TO = credentials("${JENKINS_EMAIL_CREDS_ID}") PR_BRANCH_HASH = "${util.generateHash(10)}" - } stages { @@ -103,7 +102,7 @@ pipeline { stage('Prepare for PR') { when { - expression { return isRelease() || isCreatePr() } + expression { return isCreatePr() } } steps { script { @@ -144,19 +143,15 @@ pipeline { .withProperty('maven.test.failure.ignore', true) .withProperty('operator.image.build') .skipTests(params.SKIP_TESTS) - def Closure mavenRunClosure = { - configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { - mavenCommand.withSettingsXmlFile(MAVEN_SETTINGS_FILE).run("clean $installOrDeploy") - } - } + if (isRelease()) { release.gpgImportKeyFromStringWithoutPassword(getReleaseGpgSignKeyCredsId()) mavenCommand.withProfiles(['apache-release']) - mavenRunClosure() - } else { - mavenRunClosure() } + configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { + mavenCommand.withSettingsXmlFile(MAVEN_SETTINGS_FILE).run("clean $installOrDeploy") + } } if (isRelease()) { updateAntoraYaml(optaplannerFolder) @@ -176,7 +171,7 @@ pipeline { stage('Build Quickstarts') { steps { script { - configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]){ + configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { getOptaplannerQuickstartsMavenCommand() .withProperty('maven.test.failure.ignore', true) .skipTests(params.SKIP_TESTS) @@ -197,7 +192,7 @@ pipeline { stage('Create PRs') { when { - expression { return isRelease() || isCreatePr() } + expression { return isCreatePr() } } steps { script { @@ -217,6 +212,18 @@ pipeline { } } + stage('Commit and Create Tag') { + when { + expression { return isRelease() } + } + steps { + script { + commitAndCreateTag(optaplannerFolder, getBuildBranch()) + commitAndCreateTag(quickstartsFolder, getQuickStartsBranch()) + } + } + } + stage('Push a temporary operator image to a registry') { when { expression { return isRelease() } @@ -255,7 +262,7 @@ pipeline { void sendErrorNotification() { if (params.SEND_NOTIFICATION) { String additionalInfo = "**[${getBuildBranch()}] Optaplanner - Deploy**" - mailer.sendMarkdownTestSummaryNotification("CI failures", [env.OPTAPLANNER_CI_EMAIL_TO], additionalInfo) + mailer.sendMarkdownTestSummaryNotification('CI failures', [env.OPTAPLANNER_CI_EMAIL_TO], additionalInfo) } else { echo 'No notification sent per configuration' } @@ -335,6 +342,20 @@ void prepareForPR(String folder) { } } +void commitAndCreateTag(String folder, String buildBranch) { + dir(folder) { + def commitMsg = "[${buildBranch}] Update project version to ${getProjectVersion()}" + githubscm.setUserConfigFromCreds(getGitAuthorPushCredsId()) + githubscm.commitChanges(commitMsg, { + githubscm.findAndStageNotIgnoredFiles('pom.xml') + githubscm.findAndStageNotIgnoredFiles('build.gradle') + githubscm.findAndStageNotIgnoredFiles('antora.yml') + }) + githubscm.tagRepository(getGitTagName()) + githubscm.pushRemoteTag('origin', getGitTagName(), getGitAuthorPushCredsId()) + } +} + void commitAndCreatePR(String folder, String repo, String buildBranch) { dir(folder) { def commitMsg = "[${buildBranch}] Update project version to ${getProjectVersion()}" @@ -385,7 +406,7 @@ MavenCommand getOptaplannerQuickstartsMavenCommand() { * Builds the parent modules and the BOM so that project depending on these artifacts can resolve. */ void mavenCleanInstallOptaPlannerParents() { - configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]){ + configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { getOptaplannerMavenCommand() .skipTests(true) .withOptions(['-U', '-pl org.optaplanner:optaplanner-build-parent,org.optaplanner:optaplanner-bom', '-am']) @@ -403,7 +424,7 @@ void runMavenDeploy(MavenCommand mvnCmd, String localDeploymentId = '') { mvnCmd.withDeployRepository(env.MAVEN_DEPLOY_REPOSITORY) } - configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]){ + configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { mvnCmd .withSettingsXmlFile(MAVEN_SETTINGS_FILE) .skipTests(true) @@ -532,4 +553,8 @@ String getReleaseGpgSignKeyCredsId() { String getReleaseGpgSignPassphraseCredsId() { return env.RELEASE_GPG_SIGN_PASSPHRASE_CREDS_ID -} \ No newline at end of file +} + +String getGitTagName() { + return params.GIT_TAG_NAME +} diff --git a/.ci/jenkins/dsl/jobs.groovy b/.ci/jenkins/dsl/jobs.groovy index 64a62c5919f..d189091f687 100644 --- a/.ci/jenkins/dsl/jobs.groovy +++ b/.ci/jenkins/dsl/jobs.groovy @@ -149,19 +149,14 @@ void setupProjectReleaseJob() { GIT_BRANCH_NAME: "${GIT_BRANCH}", GIT_AUTHOR: "${GIT_AUTHOR_NAME}", - - DEFAULT_STAGING_REPOSITORY: "${MAVEN_NEXUS_STAGING_PROFILE_URL}", - ARTIFACTS_REPOSITORY: "${MAVEN_ARTIFACTS_REPOSITORY}", - OPTAPLANNER_LATEST_STREAM: "${GIT_MAIN_BRANCH}" ]) KogitoJobTemplate.createPipelineJob(this, jobParams)?.with { parameters { stringParam('RESTORE_FROM_PREVIOUS_JOB', '', 'URL to a previous stopped release job which needs to be continued') - stringParam('OPTAPLANNER_VERSION', '', 'Project version of OptaPlanner and its examples to release as Major.minor.micro') - stringParam('OPTAPLANNER_RELEASE_BRANCH', '', '(optional) Use to override the release branch name deduced from the OPTAPLANNER_VERSION') + stringParam('RELEASE_VERSION', '', 'Project version of OptaPlanner and its examples to release as Major.minor.micro') - stringParam('DROOLS_VERSION', '', '(optional) Drools version to be set to the project before releasing the artifacts.') + stringParam('GIT_TAG_NAME', '', 'Git tag to create. i.e.: 10.0.0-rc1') booleanParam('SKIP_TESTS', false, 'Skip all tests') } @@ -370,6 +365,8 @@ void setupDeployJob(JobType jobType, String envName = '') { stringParam('OPERATOR_IMAGE_REGISTRY_TOKEN_CREDENTIALS_ID', "${CLOUD_IMAGE_REGISTRY_TOKEN_CREDENTIALS_ID}", 'Image registry token credentials id.') stringParam('OPERATOR_IMAGE_NAMESPACE', "${CLOUD_IMAGE_NAMESPACE}", 'Operator image namespace to use to deploy image.') stringParam('OPERATOR_IMAGE_TAG', '', 'Image tag to use to deploy the operator image. OptaPlanner project version if not set.') + + stringParam('GIT_TAG_NAME', '', 'Optional if not RELEASE. Tag to be created in the repository') } } } diff --git a/.ci/jenkins/project/Jenkinsfile.release b/.ci/jenkins/project/Jenkinsfile.release index b52329f201d..61fcf539d45 100644 --- a/.ci/jenkins/project/Jenkinsfile.release +++ b/.ci/jenkins/project/Jenkinsfile.release @@ -22,10 +22,8 @@ import org.jenkinsci.plugins.workflow.libs.Library @Library('jenkins-pipeline-shared-libraries')_ OPTAPLANNER_DEPLOY = 'optaplanner-deploy' -OPTAPLANNER_PROMOTE = 'optaplanner-promote' ARTIFACTS_STAGING_STAGE = 'stage.artifacts.staging' -ARTIFACTS_RELEASE_STAGE = 'stage.artifacts.release' JOB_PROPERTY_PREFIX = 'build' JOB_RESULT_PROPERTY_KEY = 'result' @@ -54,24 +52,17 @@ pipeline { echo "Release properties imported from previous job: ${releaseProperties}" } - assert getOptaPlannerVersion() + assert getReleaseVersion() currentBuild.displayName = getDisplayName() - sendNotification("Release Pipeline has started...\nOptaplanner version = ${getOptaPlannerVersion()}\n=> ${env.BUILD_URL}") - - // Safety measure to not publish to main JBoss - if (getGitAuthor() != 'apache' && !getArtifactsRepositoryParam()) { - sendNotification("Git Author is different from `apache` and no `ARTIFACTS_REPOSITORY` parameter has been provided. Are you sure you want to continue ? => ${env.BUILD_URL}input") - input message: 'Should the pipeline continue with no `ARTIFACTS_REPOSITORY` defined ?', ok: 'Yes' - } + sendNotification("Release Pipeline has started...\nOptaplanner version = ${getReleaseVersion()}\n=> ${env.BUILD_URL}") } } post { always { - setReleasePropertyIfneeded('optaplanner.version', getOptaPlannerVersion()) - setReleasePropertyIfneeded('optaplanner.branch', getOptaPlannerReleaseBranch()) - setReleasePropertyIfneeded('drools.version', getDroolsVersion()) + setReleasePropertyIfneeded('release.version', getReleaseVersion()) + setReleasePropertyIfneeded('git.tag.name', getGitTagName()) } } } @@ -82,7 +73,6 @@ pipeline { def buildParams = getDefaultBuildParams() addSkipTestsParam(buildParams) addSkipIntegrationTestsParam(buildParams) - addStringParam(buildParams, 'QUICKSTARTS_BUILD_BRANCH_NAME', getOptaPlannerReleaseBranch()) buildJob(OPTAPLANNER_DEPLOY, buildParams) } } @@ -92,54 +82,12 @@ pipeline { steps { script { if (!areArtifactsStaged()) { - sendNotification("All artifacts have been staged. You can find them here: ${getStagingRepository()}") + sendNotification('All artifacts have been staged.') } setArtifactsStaged() } } } - - stage('Are staged artifacts released?') { - when { - // Execute only if artifacts repository was not given, which means the staging repository has been created - expression { return !getArtifactsRepositoryParam() && !areArtifactsReleased() } - } - steps { - script { - String body = "${getOptaPlannerVersion()} artifacts are ready for release.\n" + - "Please release the staging repositories and then confirm here: ${env.BUILD_URL}input" - sendNotification(body) - input message: 'Has the staging repository been released ?', ok: 'Yes' - - sendNotification('Artifacts have been released. Finalizing now the release ...') - setArtifactsReleased() - } - } - } - - stage('Promote OptaPlanner') { - when { - expression { return isJobConsideredOk(OPTAPLANNER_DEPLOY) } - } - steps { - script { - def buildParams = getDefaultBuildParams() - addDeployBuildUrlParam(buildParams, OPTAPLANNER_DEPLOY) - - buildJob(OPTAPLANNER_PROMOTE, buildParams) - } - } - } - - stage('Setup next snapshot version') { - steps { - script { - def buildParams = [] - addStringParam(buildParams, 'OPTAPLANNER_VERSION', util.getNextVersion(getOptaPlannerVersion(), 'micro')) - build(job: '../setup-branch/0-setup-branch', wait: false, parameters: buildParams, propagate: false) - } - } - } } post { always { @@ -301,9 +249,10 @@ def readPropertiesFromUrl(String url, String propsFilename) { List getDefaultBuildParams() { List buildParams = [] - addDisplayNameParam(buildParams, getDisplayName(getOptaPlannerVersion())) - addStringParam(buildParams, 'PROJECT_VERSION', getOptaPlannerVersion()) - addStringParam(buildParams, 'DROOLS_VERSION', getDroolsVersion()) + addDisplayNameParam(buildParams, getDisplayName(getReleaseVersion())) + addStringParam(buildParams, 'PROJECT_VERSION', getReleaseVersion()) + addStringParam(buildParams, 'DROOLS_VERSION', getReleaseVersion()) + addStringParam(buildParams, 'GIT_TAG_NAME', getGitTagName()) return buildParams } @@ -350,30 +299,14 @@ String getDisplayName(version = '') { return "Release ${version}" } -String getOptaPlannerVersion() { - return params.OPTAPLANNER_VERSION ?: getReleaseProperty('optaplanner.version') -} - -String getDroolsVersion() { - return params.DROOLS_VERSION ?: getReleaseProperty('drools.version') +String getReleaseVersion() { + return params.RELEASE_VERSION ?: getReleaseProperty('release.version') } String getGitAuthor() { return env.GIT_AUTHOR } -String getArtifactsRepositoryParam() { - return env['ARTIFACTS_REPOSITORY'] ?: '' -} - -String getOptaPlannerReleaseBranch() { - return params.OPTAPLANNER_RELEASE_BRANCH ?: (getReleaseProperty('optaplanner.branch') ?: util.getReleaseBranchFromVersion(getOptaPlannerVersion())) -} - -String getStagingRepository() { - return getArtifactsRepositoryParam() ?: env.DEFAULT_STAGING_REPOSITORY -} - void setReleasePropertyIfneeded(String key, def value) { if (value) { releaseProperties[key] = value @@ -402,10 +335,6 @@ void setArtifactsStaged() { setReleasePropertyIfneeded(ARTIFACTS_STAGING_STAGE, true) } -boolean areArtifactsReleased() { - return hasReleaseProperty(ARTIFACTS_RELEASE_STAGE) -} - -void setArtifactsReleased() { - setReleasePropertyIfneeded(ARTIFACTS_RELEASE_STAGE, true) +String getGitTagName() { + return params.GIT_TAG_NAME ?: getReleaseProperty('git.tag.name') } From aa73f300292c17a3e173b9c9f534bac822f44488 Mon Sep 17 00:00:00 2001 From: Rodrigo Antunes Date: Wed, 14 Aug 2024 13:13:34 -0300 Subject: [PATCH 2/7] [10.0.x] NO-ISSUE: Fix release configuration keys (#3116) * Fix release configuration keys * Rename release.groovy file to avoid conflicts with the RELEASE env var * Switch to GPG File Jenkins secret --- .ci/jenkins/Jenkinsfile.deploy | 2 +- .ci/jenkins/config/branch.yaml | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/.ci/jenkins/Jenkinsfile.deploy b/.ci/jenkins/Jenkinsfile.deploy index 771331d5692..2a06609679a 100644 --- a/.ci/jenkins/Jenkinsfile.deploy +++ b/.ci/jenkins/Jenkinsfile.deploy @@ -145,7 +145,7 @@ pipeline { .skipTests(params.SKIP_TESTS) if (isRelease()) { - release.gpgImportKeyFromStringWithoutPassword(getReleaseGpgSignKeyCredsId()) + releaseUtils.gpgImportKeyFromStringWithoutPassword(getReleaseGpgSignKeyCredsId()) mavenCommand.withProfiles(['apache-release']) } diff --git a/.ci/jenkins/config/branch.yaml b/.ci/jenkins/config/branch.yaml index 316bb688025..0403272be83 100644 --- a/.ci/jenkins/config/branch.yaml +++ b/.ci/jenkins/config/branch.yaml @@ -87,8 +87,8 @@ cloud: release: gpg: sign: - key-credentials-id: 'GPG_KEY' - passphrase-credentials-id: '' + key_credentials_id: GPG_KEY_FILE + passphrase_credentials_id: '' jenkins: email_creds_id: OPTAPLANNER_CI_NOTIFICATION_EMAILS agent: From 83c7027b863349e493bc778c127e94735db11bf9 Mon Sep 17 00:00:00 2001 From: Rodrigo Antunes Date: Wed, 14 Aug 2024 13:58:50 -0300 Subject: [PATCH 3/7] [10.0.x] NO-ISSUE: Fix release job display name (#3117) Fix release job display name --- .ci/jenkins/project/Jenkinsfile.release | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.ci/jenkins/project/Jenkinsfile.release b/.ci/jenkins/project/Jenkinsfile.release index 61fcf539d45..2119bc50cf4 100644 --- a/.ci/jenkins/project/Jenkinsfile.release +++ b/.ci/jenkins/project/Jenkinsfile.release @@ -295,7 +295,7 @@ String constructKey(String prefix, String paramId) { } String getDisplayName(version = '') { - version = version ?: getOptaPlannerVersion() + version = version ?: getReleaseVersion() return "Release ${version}" } From d5e15d6ea30b05d40b01bc6267d7a4889d3a3c43 Mon Sep 17 00:00:00 2001 From: Rodrigo Antunes Date: Mon, 19 Aug 2024 14:03:37 -0300 Subject: [PATCH 4/7] [10.0.x] NO-ISSUE: Setup nexus credentials to build parent modules (#3119) Setup nexus credentials to build parent modules --- .ci/jenkins/Jenkinsfile.deploy | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/.ci/jenkins/Jenkinsfile.deploy b/.ci/jenkins/Jenkinsfile.deploy index 2a06609679a..a828be9b415 100644 --- a/.ci/jenkins/Jenkinsfile.deploy +++ b/.ci/jenkins/Jenkinsfile.deploy @@ -406,12 +406,16 @@ MavenCommand getOptaplannerQuickstartsMavenCommand() { * Builds the parent modules and the BOM so that project depending on these artifacts can resolve. */ void mavenCleanInstallOptaPlannerParents() { - configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { - getOptaplannerMavenCommand() - .skipTests(true) - .withOptions(['-U', '-pl org.optaplanner:optaplanner-build-parent,org.optaplanner:optaplanner-bom', '-am']) - .withSettingsXmlFile(MAVEN_SETTINGS_FILE) - .run('clean install') + withCredentials([usernamePassword(credentialsId: env.MAVEN_REPO_CREDS_ID, usernameVariable: 'REPOSITORY_USER', passwordVariable: 'REPOSITORY_TOKEN')]) { + configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { + getOptaplannerMavenCommand() + .skipTests(true) + .withOptions(['-U', '-pl org.optaplanner:optaplanner-build-parent,org.optaplanner:optaplanner-bom', '-am']) + .withSettingsXmlFile(MAVEN_SETTINGS_FILE) + .withProperty('apache.repository.username', "${REPOSITORY_USER}") + .withProperty('apache.repository.password', "${REPOSITORY_TOKEN}") + .run('clean install') + } } } From 509f4ef0e76784651c77c136112f04f76b6746e7 Mon Sep 17 00:00:00 2001 From: Rodrigo Antunes Date: Tue, 20 Aug 2024 10:28:06 -0300 Subject: [PATCH 5/7] [10.0.x] NO-ISSUE: Use release settings to update version and parent versions (#3120) Use release settings to update version and parent version --- .ci/jenkins/Jenkinsfile.deploy | 31 ++++++++++++++++--------------- 1 file changed, 16 insertions(+), 15 deletions(-) diff --git a/.ci/jenkins/Jenkinsfile.deploy b/.ci/jenkins/Jenkinsfile.deploy index a828be9b415..7684fa089e8 100644 --- a/.ci/jenkins/Jenkinsfile.deploy +++ b/.ci/jenkins/Jenkinsfile.deploy @@ -118,10 +118,12 @@ pipeline { } steps { script { - if (getDroolsVersion()) { - maven.mvnSetVersionProperty(getOptaplannerMavenCommand(), 'version.org.drools', getDroolsVersion()) + configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { + if (getDroolsVersion()) { + maven.mvnSetVersionProperty(getOptaplannerMavenCommand().withSettingsXmlFile(MAVEN_SETTINGS_FILE), 'version.org.drools', getDroolsVersion()) + } + maven.mvnVersionsSet(getOptaplannerMavenCommand().withSettingsXmlFile(MAVEN_SETTINGS_FILE), getProjectVersion(), !isRelease()) } - maven.mvnVersionsSet(getOptaplannerMavenCommand(), getProjectVersion(), !isRelease()) mavenCleanInstallOptaPlannerParents() updateQuickstartsVersions() } @@ -273,8 +275,11 @@ List getIntegrationTestProfiles() { } void updateQuickstartsVersions() { - maven.mvnSetVersionProperty(getOptaplannerQuickstartsMavenCommand(), 'version.org.optaplanner', getProjectVersion()) - maven.mvnVersionsUpdateParentAndChildModules(getOptaplannerQuickstartsMavenCommand(), getProjectVersion(), !isRelease()) + configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { + maven.mvnSetVersionProperty(getOptaplannerQuickstartsMavenCommand().withSettingsXmlFile(MAVEN_SETTINGS_FILE), 'version.org.optaplanner', getProjectVersion()) + maven.mvnVersionsUpdateParentAndChildModules(getOptaplannerQuickstartsMavenCommand().withSettingsXmlFile(MAVEN_SETTINGS_FILE), getProjectVersion(), !isRelease()) + } + gradleVersionsUpdate(quickstartsFolder, getProjectVersion()) if (isRelease()) { @@ -406,16 +411,12 @@ MavenCommand getOptaplannerQuickstartsMavenCommand() { * Builds the parent modules and the BOM so that project depending on these artifacts can resolve. */ void mavenCleanInstallOptaPlannerParents() { - withCredentials([usernamePassword(credentialsId: env.MAVEN_REPO_CREDS_ID, usernameVariable: 'REPOSITORY_USER', passwordVariable: 'REPOSITORY_TOKEN')]) { - configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { - getOptaplannerMavenCommand() - .skipTests(true) - .withOptions(['-U', '-pl org.optaplanner:optaplanner-build-parent,org.optaplanner:optaplanner-bom', '-am']) - .withSettingsXmlFile(MAVEN_SETTINGS_FILE) - .withProperty('apache.repository.username', "${REPOSITORY_USER}") - .withProperty('apache.repository.password', "${REPOSITORY_TOKEN}") - .run('clean install') - } + configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { + getOptaplannerMavenCommand() + .skipTests(true) + .withOptions(['-U', '-pl org.optaplanner:optaplanner-build-parent,org.optaplanner:optaplanner-bom', '-am']) + .withSettingsXmlFile(MAVEN_SETTINGS_FILE) + .run('clean install') } } From 4f7456a1479380bc7c4a0685bb6e78d2597d967f Mon Sep 17 00:00:00 2001 From: Rodrigo Antunes Date: Fri, 23 Aug 2024 13:04:25 -0300 Subject: [PATCH 6/7] [10.0.x] NO-ISSUE: Disable generate-code-tests goal and fixes for the release job (#3121) Disable generate-code-tests goal and fixes for the release job --- .ci/jenkins/Jenkinsfile.deploy | 66 +++++++++++++++------------------- optaplanner-operator/pom.xml | 3 +- 2 files changed, 31 insertions(+), 38 deletions(-) diff --git a/.ci/jenkins/Jenkinsfile.deploy b/.ci/jenkins/Jenkinsfile.deploy index 7684fa089e8..854766ca685 100644 --- a/.ci/jenkins/Jenkinsfile.deploy +++ b/.ci/jenkins/Jenkinsfile.deploy @@ -118,12 +118,10 @@ pipeline { } steps { script { - configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { - if (getDroolsVersion()) { - maven.mvnSetVersionProperty(getOptaplannerMavenCommand().withSettingsXmlFile(MAVEN_SETTINGS_FILE), 'version.org.drools', getDroolsVersion()) - } - maven.mvnVersionsSet(getOptaplannerMavenCommand().withSettingsXmlFile(MAVEN_SETTINGS_FILE), getProjectVersion(), !isRelease()) + if (getDroolsVersion()) { + maven.mvnSetVersionProperty(getOptaplannerMavenCommand(), 'version.org.drools', getDroolsVersion()) } + maven.mvnVersionsSet(getOptaplannerMavenCommand(), getProjectVersion(), !isRelease()) mavenCleanInstallOptaPlannerParents() updateQuickstartsVersions() } @@ -173,12 +171,16 @@ pipeline { stage('Build Quickstarts') { steps { script { - configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { - getOptaplannerQuickstartsMavenCommand() + withCredentials([usernamePassword(credentialsId: env.MAVEN_REPO_CREDS_ID, usernameVariable: 'REPOSITORY_USER', passwordVariable: 'REPOSITORY_TOKEN')]) { + configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { + getOptaplannerQuickstartsMavenCommand() .withProperty('maven.test.failure.ignore', true) .skipTests(params.SKIP_TESTS) .withSettingsXmlFile(MAVEN_SETTINGS_FILE) + .withProperty('apache.repository.username', REPOSITORY_USER) + .withProperty('apache.repository.password', REPOSITORY_TOKEN) .run('clean install') + } } } } @@ -270,14 +272,20 @@ void sendErrorNotification() { } } -List getIntegrationTestProfiles() { - return params.SKIP_INTEGRATION_TESTS ? [] : ['integration-tests'] -} - void updateQuickstartsVersions() { - configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { - maven.mvnSetVersionProperty(getOptaplannerQuickstartsMavenCommand().withSettingsXmlFile(MAVEN_SETTINGS_FILE), 'version.org.optaplanner', getProjectVersion()) - maven.mvnVersionsUpdateParentAndChildModules(getOptaplannerQuickstartsMavenCommand().withSettingsXmlFile(MAVEN_SETTINGS_FILE), getProjectVersion(), !isRelease()) + maven.mvnSetVersionProperty(getOptaplannerQuickstartsMavenCommand(), 'version.org.optaplanner', getProjectVersion()) + maven.mvnVersionsUpdateParent(getOptaplannerQuickstartsMavenCommand(), getProjectVersion(), !isRelease()) + + withCredentials([usernamePassword(credentialsId: env.MAVEN_REPO_CREDS_ID, usernameVariable: 'REPOSITORY_USER', passwordVariable: 'REPOSITORY_TOKEN')]) { + configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { + maven.mvnVersionsUpdateChildModules( + getOptaplannerQuickstartsMavenCommand() + .withSettingsXmlFile(MAVEN_SETTINGS_FILE) + .withProperty('apache.repository.username', REPOSITORY_USER) + .withProperty('apache.repository.password', REPOSITORY_TOKEN), + !isRelease() + ) + } } gradleVersionsUpdate(quickstartsFolder, getProjectVersion()) @@ -291,6 +299,7 @@ void updateQuickstartsVersions() { 'cat', returnStdout: true) } } + if (isCreatePr()) { dir(quickstartsFolder) { // TODO: Remove the exclusion after the kubernetes demo is migrated to 9. @@ -411,36 +420,19 @@ MavenCommand getOptaplannerQuickstartsMavenCommand() { * Builds the parent modules and the BOM so that project depending on these artifacts can resolve. */ void mavenCleanInstallOptaPlannerParents() { - configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { - getOptaplannerMavenCommand() + withCredentials([usernamePassword(credentialsId: env.MAVEN_REPO_CREDS_ID, usernameVariable: 'REPOSITORY_USER', passwordVariable: 'REPOSITORY_TOKEN')]) { + configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { + getOptaplannerMavenCommand() .skipTests(true) .withOptions(['-U', '-pl org.optaplanner:optaplanner-build-parent,org.optaplanner:optaplanner-bom', '-am']) .withSettingsXmlFile(MAVEN_SETTINGS_FILE) + .withProperty('apache.repository.username', REPOSITORY_USER) + .withProperty('apache.repository.password', REPOSITORY_TOKEN) .run('clean install') + } } } -void runMavenDeploy(MavenCommand mvnCmd, String localDeploymentId = '') { - mvnCmd = mvnCmd.clone() - - if (localDeploymentId) { - mvnCmd.withLocalDeployFolder(getLocalDeploymentFolder(localDeploymentId)) - } else if (env.MAVEN_DEPLOY_REPOSITORY) { - mvnCmd.withDeployRepository(env.MAVEN_DEPLOY_REPOSITORY) - } - - configFileProvider([configFile(fileId: env.MAVEN_SETTINGS_CONFIG_FILE_ID, variable: 'MAVEN_SETTINGS_FILE')]) { - mvnCmd - .withSettingsXmlFile(MAVEN_SETTINGS_FILE) - .skipTests(true) - .run('clean deploy') - } -} - -String getMavenRepoZipUrl() { - return "${params.MAVEN_DEPLOY_REPOSITORY.replaceAll('/content/', '/service/local/').replaceFirst('/*$', '')}/content-compressed" -} - // Getters and Setters of params/properties boolean shouldDeployToRepository() { diff --git a/optaplanner-operator/pom.xml b/optaplanner-operator/pom.xml index d49f08a2b87..c2c591b93ae 100644 --- a/optaplanner-operator/pom.xml +++ b/optaplanner-operator/pom.xml @@ -115,7 +115,8 @@ build generate-code - generate-code-tests + From f9d7608429dd0b2bdda7567ca7e14ebeae5f402a Mon Sep 17 00:00:00 2001 From: Rodrigo Antunes Date: Tue, 17 Sep 2024 14:38:53 -0300 Subject: [PATCH 7/7] Release job updates and fixes for Apache 10 release --- optaplanner-operator/pom.xml | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/optaplanner-operator/pom.xml b/optaplanner-operator/pom.xml index c2c591b93ae..d49f08a2b87 100644 --- a/optaplanner-operator/pom.xml +++ b/optaplanner-operator/pom.xml @@ -115,8 +115,7 @@ build generate-code - + generate-code-tests