Merge branch 'feature/18208'
This commit is contained in:
commit
6e93df90e1
|
@ -5,7 +5,7 @@ import org.yaml.snakeyaml.Yaml
|
||||||
def (options, maven_local_repo_path, maven_settings_file, maven_parent_file) = ['', '', '', '']
|
def (options, maven_local_repo_path, maven_settings_file, maven_parent_file) = ['', '', '', '']
|
||||||
def agent_root_folder = '/var/lib/jenkins/.m2'
|
def agent_root_folder = '/var/lib/jenkins/.m2'
|
||||||
def verbose = true
|
def verbose = true
|
||||||
|
def resume = params.resume_from
|
||||||
if (params.Type == 'SNAPSHOT-DRY-RUN') {
|
if (params.Type == 'SNAPSHOT-DRY-RUN') {
|
||||||
echo "Configure Maven for SNAPSHOT-DRY-RUN artifacts"
|
echo "Configure Maven for SNAPSHOT-DRY-RUN artifacts"
|
||||||
options = ''
|
options = ''
|
||||||
|
@ -47,6 +47,7 @@ echo "Use local repo at ${maven_local_repo_path}"
|
||||||
echo "Release number: ${params.gCube_release_version}"
|
echo "Release number: ${params.gCube_release_version}"
|
||||||
echo "Clean up gcube local artifacts? ${params.cleanup_gcube_artifacts}"
|
echo "Clean up gcube local artifacts? ${params.cleanup_gcube_artifacts}"
|
||||||
echo "Clean up all local artifacts? ${params.cleanup_local_repo}"
|
echo "Clean up all local artifacts? ${params.cleanup_local_repo}"
|
||||||
|
echo "Resume from previous build? ${params.resume_from}"
|
||||||
|
|
||||||
|
|
||||||
//locate the release file
|
//locate the release file
|
||||||
|
@ -69,6 +70,12 @@ if (verbose) {
|
||||||
jsonConfig.gCube_release.Components.each { println it.key }
|
jsonConfig.gCube_release.Components.each { println it.key }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def jobs = [:]
|
||||||
|
def previous_report_content = ''
|
||||||
|
def previous_report_file = "${agent_root_folder}/build_jobs.${resume}.csv"
|
||||||
|
def previous_commit_file = "${agent_root_folder}/build_commits.${resume}.csv"
|
||||||
|
|
||||||
|
|
||||||
pipeline {
|
pipeline {
|
||||||
|
|
||||||
// see https://jenkins.io/doc/book/pipeline/syntax/#agent
|
// see https://jenkins.io/doc/book/pipeline/syntax/#agent
|
||||||
|
@ -90,6 +97,10 @@ pipeline {
|
||||||
GCUBE_RELEASE_NUMBER = "${params.gCube_release_version}"
|
GCUBE_RELEASE_NUMBER = "${params.gCube_release_version}"
|
||||||
PIPELINE_BUILD_NUMBER = "${env.BUILD_NUMBER}"
|
PIPELINE_BUILD_NUMBER = "${env.BUILD_NUMBER}"
|
||||||
TYPE = "${params.Type}"
|
TYPE = "${params.Type}"
|
||||||
|
RESUME = "${params.resume}"
|
||||||
|
JOB_REPORT = "${agent_root_folder}/build_jobs.${env.BUILD_NUMBER}.csv"
|
||||||
|
PREVIOUS_JOB_REPORT = "${previous_report_file}"
|
||||||
|
PREVIOUS_COMMIT_REPORT = "${previous_commit_file}"
|
||||||
}
|
}
|
||||||
|
|
||||||
// see https://jenkins.io/doc/book/pipeline/syntax/#parameters
|
// see https://jenkins.io/doc/book/pipeline/syntax/#parameters
|
||||||
|
@ -109,44 +120,84 @@ pipeline {
|
||||||
booleanParam(name: 'cleanup_local_repo',
|
booleanParam(name: 'cleanup_local_repo',
|
||||||
defaultValue: true,
|
defaultValue: true,
|
||||||
description: 'Wipe out the local maven repository before the builds?')
|
description: 'Wipe out the local maven repository before the builds?')
|
||||||
|
|
||||||
|
string(name: 'resume_from',
|
||||||
|
defaultValue: '',
|
||||||
|
description: 'Resume from a previous build identified by the build number.')
|
||||||
}
|
}
|
||||||
|
|
||||||
//see https://jenkins.io/doc/book/pipeline/syntax/#stages
|
//see https://jenkins.io/doc/book/pipeline/syntax/#stages
|
||||||
stages {
|
stages {
|
||||||
stage('initialize') {
|
stage('initialize reports') {
|
||||||
|
steps {
|
||||||
|
script {
|
||||||
|
if (resume) {
|
||||||
|
content = readFile("${previous_report_file}")
|
||||||
|
println "JOB REPORT CONTENT: ${content}"
|
||||||
|
jobs = parseJobs(content)
|
||||||
|
sh "rm ${AGENT_ROOT_FOLDER}/build_commits.csv || true"
|
||||||
|
sh "cp ${PREVIOUS_COMMIT_REPORT} ${AGENT_ROOT_FOLDER}/build_commits.csv"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sh '''
|
||||||
|
# job report
|
||||||
|
echo "#Build ${PIPELINE_BUILD_NUMBER}" > ${JOB_REPORT}
|
||||||
|
echo "#StartTime ${date}" >> ${JOB_REPORT}
|
||||||
|
echo -e "JobName,Status" >> ${JOB_REPORT}
|
||||||
|
|
||||||
|
# create build report if not resumed
|
||||||
|
if [ ! -f ${AGENT_ROOT_FOLDER}/build_commits.csv ]; then
|
||||||
|
#build report
|
||||||
|
echo "#Build ${PIPELINE_BUILD_NUMBER}" > ${AGENT_ROOT_FOLDER}/build_commits.csv
|
||||||
|
echo "#Release ${GCUBE_RELEASE_NUMBER}" >> ${AGENT_ROOT_FOLDER}/build_commits.csv
|
||||||
|
date=`date`
|
||||||
|
echo "#StartTime ${date}" >> ${AGENT_ROOT_FOLDER}/build_commits.csv
|
||||||
|
echo -e "GroupID,ArtifactID,Version,SCM URL,Build Number,Distribution URL,Filename,Packaging" >> ${AGENT_ROOT_FOLDER}/build_commits.csv
|
||||||
|
fi
|
||||||
|
'''
|
||||||
|
}
|
||||||
|
}
|
||||||
|
stage('initialize local repository') {
|
||||||
steps {
|
steps {
|
||||||
sh '''
|
sh '''
|
||||||
echo "REMOVE_LOCAL_REPO: ${REMOVE_LOCAL_REPO}"
|
echo "REMOVE_LOCAL_REPO: ${REMOVE_LOCAL_REPO}"
|
||||||
echo "CLEANUP_GCUBE_REPO: ${CLEANUP_GCUBE_REPO}"
|
echo "CLEANUP_GCUBE_REPO: ${CLEANUP_GCUBE_REPO}"
|
||||||
if [ "$CLEANUP_GCUBE_REPO" = "true" ]; then
|
if [ "$CLEANUP_GCUBE_REPO" = "true" ]; then
|
||||||
echo "Remove gCube artifacts from local repository"
|
echo "Remove gCube artifacts from local repository"
|
||||||
rm -rf $MAVEN_LOCAL_REPO/org/gcube
|
rm -rf $MAVEN_LOCAL_REPO/org/gcube
|
||||||
fi
|
fi
|
||||||
if [ "$REMOVE_LOCAL_REPO" = "true" ]; then
|
if [ "$REMOVE_LOCAL_REPO" = "true" ]; then
|
||||||
echo "Create a fresh local repository"
|
echo "Create a fresh local repository"
|
||||||
rm -rf $MAVEN_LOCAL_REPO
|
rm -rf $MAVEN_LOCAL_REPO
|
||||||
mkdir -p $MAVEN_LOCAL_REPO
|
mkdir -p $MAVEN_LOCAL_REPO
|
||||||
fi
|
fi
|
||||||
mv "${AGENT_ROOT_FOLDER}/settings.xml" "${AGENT_ROOT_FOLDER}/settings.${PIPELINE_BUILD_NUMBER}"
|
mv "${AGENT_ROOT_FOLDER}/settings.xml" "${AGENT_ROOT_FOLDER}/settings.${PIPELINE_BUILD_NUMBER}"
|
||||||
cp "${AGENT_ROOT_FOLDER}/${MAVEN_SETTINGS_FILE}" "${AGENT_ROOT_FOLDER}/settings.xml"
|
cp "${AGENT_ROOT_FOLDER}/${MAVEN_SETTINGS_FILE}" "${AGENT_ROOT_FOLDER}/settings.xml"
|
||||||
echo "Done with local repository and settings"
|
echo "Done with local repository and settings"
|
||||||
echo "#Build ${PIPELINE_BUILD_NUMBER}" > ${AGENT_ROOT_FOLDER}/build_commits.csv
|
|
||||||
echo "#Release ${GCUBE_RELEASE_NUMBER}" >> ${AGENT_ROOT_FOLDER}/build_commits.csv
|
|
||||||
date=`date`
|
|
||||||
echo "#StartTime ${date}" >> ${AGENT_ROOT_FOLDER}/build_commits.csv
|
|
||||||
echo -e "GroupID,ArtifactID,Version,SCM URL,Build Number,Distribution URL,Filename,Packaging" >> ${AGENT_ROOT_FOLDER}/build_commits.csv
|
|
||||||
'''
|
'''
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// the maven-parent needs to be built (once) at each execution
|
// the maven-parent needs to be built (once) at each execution
|
||||||
stage('build maven-parent') {
|
stage('build maven-parent') {
|
||||||
steps {
|
steps {
|
||||||
echo build(job: 'maven-parent', wait: true,
|
script {
|
||||||
parameters: [[$class: 'StringParameterValue', name: 'gcube_settings', value: "${maven_parent_file}"],
|
if (jobs['maven-parent'] == 'SUCCESS') {
|
||||||
[$class: 'StringParameterValue', name: 'local_repo', value: "${maven_local_repo_path}"],
|
echo "Skipping maven-parent"
|
||||||
[$class: 'LabelParameterValue', name: 'exec_label', label: "CD", nodeEligibility: [$class: 'AllNodeEligibility']]
|
// propagate success
|
||||||
]).result
|
sh "echo -e maven-parent,SUCCESS >> ${agent_root_folder}/build_jobs.${env.BUILD_NUMBER}.csv"
|
||||||
echo "Done with maven-parent"
|
} else {
|
||||||
|
def gjob = build(job: 'maven-parent', wait: true, propagate: true,
|
||||||
|
parameters: [[$class: 'StringParameterValue', name: 'gcube_settings', value: "${maven_parent_file}"],
|
||||||
|
[$class: 'StringParameterValue', name: 'local_repo', value: "${maven_local_repo_path}"],
|
||||||
|
[$class: 'LabelParameterValue', name: 'exec_label', label: "CD", nodeEligibility: [$class: 'AllNodeEligibility']]
|
||||||
|
])
|
||||||
|
sh "echo -e maven-parent,${gjob.getResult()} >> ${agent_root_folder}/build_jobs.${env.BUILD_NUMBER}.csv"
|
||||||
|
echo "Done with maven-parent"
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
stage('build components') {
|
stage('build components') {
|
||||||
|
@ -155,7 +206,7 @@ pipeline {
|
||||||
jsonConfig.gCube_release.Components.each { group_name, component_list ->
|
jsonConfig.gCube_release.Components.each { group_name, component_list ->
|
||||||
stage("build ${group_name} components") {
|
stage("build ${group_name} components") {
|
||||||
buildComponents items: component_list?.collect { "${it.name}" },
|
buildComponents items: component_list?.collect { "${it.name}" },
|
||||||
"${maven_settings_file}", "${maven_local_repo_path}"
|
"${maven_settings_file}", "${maven_local_repo_path}", jobs
|
||||||
echo "Done with ${group_name} components"
|
echo "Done with ${group_name} components"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -172,6 +223,7 @@ pipeline {
|
||||||
mv "${AGENT_ROOT_FOLDER}/settings.${PIPELINE_BUILD_NUMBER}" "${AGENT_ROOT_FOLDER}/settings.xml"
|
mv "${AGENT_ROOT_FOLDER}/settings.${PIPELINE_BUILD_NUMBER}" "${AGENT_ROOT_FOLDER}/settings.xml"
|
||||||
mv ${AGENT_ROOT_FOLDER}/build_commits.csv ${AGENT_ROOT_FOLDER}/build_commits.${PIPELINE_BUILD_NUMBER}.csv
|
mv ${AGENT_ROOT_FOLDER}/build_commits.csv ${AGENT_ROOT_FOLDER}/build_commits.${PIPELINE_BUILD_NUMBER}.csv
|
||||||
cp ${AGENT_ROOT_FOLDER}/build_commits.${PIPELINE_BUILD_NUMBER}.csv .
|
cp ${AGENT_ROOT_FOLDER}/build_commits.${PIPELINE_BUILD_NUMBER}.csv .
|
||||||
|
cat ${AGENT_ROOT_FOLDER}/build_jobs.${PIPELINE_BUILD_NUMBER}.csv
|
||||||
'''
|
'''
|
||||||
}
|
}
|
||||||
echo 'The default maven settings have been restored'
|
echo 'The default maven settings have been restored'
|
||||||
|
@ -198,18 +250,45 @@ pipeline {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
def buildComponents(args, maven_settings_file, maven_local_repo_path) {
|
def buildComponents(args, maven_settings_file, maven_local_repo_path, jobs) {
|
||||||
if (args.items) {
|
if (args.items) {
|
||||||
parallel args.items?.collectEntries { name ->
|
parallel args.items?.collectEntries { name ->
|
||||||
["${name}": {
|
["${name}": {
|
||||||
if (name && !"NONE".equalsIgnoreCase(name))
|
if (name && !"NONE".equalsIgnoreCase(name)) {
|
||||||
build(job: name,
|
if ( (jobs["${name}"] == 'SUCCESS') ) {
|
||||||
|
echo "Skipping ${name}"
|
||||||
|
// propagate success
|
||||||
|
sh "echo -e ${name},SUCCESS >> ${agent_root_folder}/build_jobs.${env.BUILD_NUMBER}.csv"
|
||||||
|
} else {
|
||||||
|
def gjob = build(job: name, wait: true, propagate: true,
|
||||||
parameters: [[$class: 'StringParameterValue', name: 'gcube_settings', value: "${maven_settings_file}"],
|
parameters: [[$class: 'StringParameterValue', name: 'gcube_settings', value: "${maven_settings_file}"],
|
||||||
[$class: 'StringParameterValue', name: 'local_repo', value: "${maven_local_repo_path}"],
|
[$class: 'StringParameterValue', name: 'local_repo', value: "${maven_local_repo_path}"],
|
||||||
[$class: 'LabelParameterValue', name: 'exec_label', label: "CD", nodeEligibility: [$class: 'AllNodeEligibility']]
|
[$class: 'LabelParameterValue', name: 'exec_label', label: "CD", nodeEligibility: [$class: 'AllNodeEligibility']]
|
||||||
])
|
])
|
||||||
|
sh "echo -e ${name},${gjob.getResult()} >> ${agent_root_folder}/build_jobs.${env.BUILD_NUMBER}.csv"
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
Loads the jobs from the given report.
|
||||||
|
*/
|
||||||
|
@NonCPS
|
||||||
|
def parseJobs(content) {
|
||||||
|
def jobs = [:]
|
||||||
|
try {
|
||||||
|
for (String line : content.split('\n')) {
|
||||||
|
if (!line.startsWith('#') && !line.startsWith('JobName')) {
|
||||||
|
def columns = line.split(',')
|
||||||
|
jobs["${columns[0]}"] = columns[1]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch(Exception e) {
|
||||||
|
println "Previous job report not available or not parsable"
|
||||||
|
}
|
||||||
|
jobs;
|
||||||
|
}
|
Loading…
Reference in New Issue