// this is done automaticaly by the multibranch pipeline plugin
// git url: "${url_prefix}/${project}"
+ sh "git fetch --tags"
sh "git fetch origin ${refspec}"
if (GERRIT_PATCHSET_REVISION.size() > 0 ) {
sh "git checkout -f ${revision}"
}
+ sh "sudo git clean -dfx"
}
def ci_pipeline(mdg,url_prefix,project,branch,refspec,revision,do_stage_3,artifactory_server,docker_args="",do_stage_4=false) {
println("do_stage_3= ${do_stage_3}")
ci_helper = load "devops/jenkins/ci-pipelines/ci_helper.groovy"
+ def isMergeJob = JOB_NAME.contains('merge')
stage('Prepare') {
sh 'env'
}
stage('License Scan') {
+ if (!isMergeJob) {
sh "devops/tools/license_scan.sh"
+ }
+ else {
+ println("skip the scan for merge")
+ }
+ }
+
+ stage('Release Note Check') {
+ if (fileExists('devops-stages/stage-releasenote.sh')) {
+ if (!isMergeJob) {
+ sh "devops-stages/stage-releasenote.sh"
+ }
+ else {
+ println("Not checking release notes for merge job")
+ }
+ }
+ else {
+ println("No releasenote check present")
+ }
}
container_name = "${project}-${branch}".toLowerCase()
stage('Docker-Build') {
- sh '''
- echo RUN groupadd -o -g $(id -g) -r jenkins >> Dockerfile
- echo RUN useradd -o -u $(id -u) --create-home -r -g jenkins jenkins >> Dockerfile
- '''
- sh "docker build -t ${container_name} ."
+ APT_PROXY = "http://172.21.1.1:3142"
+ sh "docker build --build-arg APT_PROXY=${APT_PROXY} -t ${container_name} ."
}
- withDockerContainer(image: "${container_name}", args: docker_args) {
+ UID = sh(returnStdout:true, script: 'id -u').trim()
+ GID = sh(returnStdout:true, script: 'id -g').trim()
+ withDockerContainer(image: "${container_name}", args: docker_args + " -u root") {
stage('Test') {
- sh 'devops-stages/stage-test.sh'
+ sh "groupadd -o -g $GID -r jenkins"
+ sh "useradd -o -u $UID -d `pwd` -r -g jenkins jenkins"
+ sh "echo '#! /bin/sh' > /usr/bin/mesg"
+ sh "chmod 755 /usr/bin/mesg"
+ sh "runuser jenkins -c devops-stages/stage-test.sh"
if (fileExists('coverage.xml')) {
cobertura coberturaReportFile: 'coverage.xml'
}
}
}
stage('Build') {
- sh(returnStdout:true, script: 'devops-stages/stage-build.sh').trim()
+ sh(returnStdout:true,
+ script: "runuser jenkins -c devops-stages/stage-build.sh").trim()
}
stage('Archive') {
- sh "mkdir -p changelog"
- sh "devops/tools/generatechangelog-pipeline.sh > changelog/changelog-${mdg}.html"
- sh(returnStdout:true, script: 'devops-stages/stage-archive.sh').trim()
+ sh "runuser jenkins -c 'mkdir -p changelog'"
+ sh "runuser jenkins -c \"devops/tools/generatechangelog-pipeline.sh > changelog/changelog-${mdg}.html\""
+ sh(returnStdout:true,
+ script: "runuser jenkins -c devops-stages/stage-archive.sh").trim()
ci_helper.archive(artifactory_server,mdg,branch,'untested')
}
}
- if ( do_stage_3 ) {
+ stage('Snap build') {
+ if (fileExists('snap/snapcraft.yaml')) {
+ withCredentials([string(credentialsId: 'Snapstore', variable: 'SNAPCRAFT_STORE_CREDENTIALS')]) {
+ sh "sudo rm -rf ${WORKSPACE}/stage/ ${WORKSPACE}/parts/ ${WORKSPACE}/prime/ ${WORKSPACE}/*.snap"
+ sh "sudo snapcraft clean --use-lxd"
+ sh "snapcraft --use-lxd"
+ sh "mv ${WORKSPACE}/${mdg}_*.snap ${WORKSPACE}/${mdg}.snap"
+ sh "sudo rm -rf ${WORKSPACE}/stage/ ${WORKSPACE}/parts/ ${WORKSPACE}/prime/"
+
+ REV=""
+ if ( ! isMergeJob ) {
+ REV="/"+"${GERRIT_REFSPEC}".replaceAll('/','-')
+ }
+ channel="latest"
+ if (BRANCH_NAME.startsWith("v")) {
+ channel=BRANCH_NAME.substring(1)
+ } else if (BRANCH_NAME!="master") {
+ REV="/"+BRANCH_NAME+REV.replaceAll('/','-')
+ }
+ sh "snapcraft push --release=${channel}/edge${REV} ${mdg}.snap"
+ sh "sudo rm -rf ${WORKSPACE}/*.snap"
+ }
+ }
+ }
+
+ if ( do_stage_3 ) {
stage('Build System') {
def downstream_params_stage_3 = [
string(name: 'GERRIT_BRANCH', value: "${branch}"),
+ string(name: 'INSTALLER', value: "Default" ),
+ string(name: 'OPENSTACK_BASE_IMAGE', value: "ubuntu20.04" ),
string(name: 'UPSTREAM_JOB_NAME', value: "${JOB_NAME}" ),
string(name: 'UPSTREAM_JOB_NUMBER', value: "${BUILD_NUMBER}" ),
booleanParam(name: 'DO_STAGE_4', value: do_stage_4 )
}
}
}
-
}
return this