From 1941149de81d0e9c0c7ae334452786ba6fff8f09 Mon Sep 17 00:00:00 2001 From: Christian Poessinger Date: Thu, 26 Aug 2021 09:00:18 +0200 Subject: Jenkins: BUILD_VERSION is now calculated during runtime In the past a cached version of BUILD_VERSION was used which would manifest in a wrong timestamp from build start time vs ISO time. --- Jenkinsfile | 42 +++++++++++++++++++++++------------------- 1 file changed, 23 insertions(+), 19 deletions(-) diff --git a/Jenkinsfile b/Jenkinsfile index e2d1836e..ea56c4a7 100644 --- a/Jenkinsfile +++ b/Jenkinsfile @@ -22,9 +22,8 @@ setDescription() node('Docker') { - stage('Build timestamp') { + stage('Setup Container') { script { - env.TIMESTAMP = sh(returnStdout: true, script: 'date -u +%Y%m%d%H%M').toString().trim() // create container name on demand def branchName = getGitBranchName() // Adjust PR target branch name so we can re-map it to the proper Docker image. @@ -39,27 +38,12 @@ node('Docker') { env.USR_ID = sh(returnStdout: true, script: 'id -u').toString().trim() env.GRP_ID = sh(returnStdout: true, script: 'id -g').toString().trim() env.DOCKER_ARGS = '--privileged --sysctl net.ipv6.conf.lo.disable_ipv6=0 -e GOSU_UID=' + env.USR_ID + ' -e GOSU_GID=' + env.GRP_ID + env.BASE_VERSION = '1.4-rolling-' } } } pipeline { - options { - disableConcurrentBuilds() - timeout(time: 150, unit: 'MINUTES') - timestamps() - buildDiscarder(logRotator(numToKeepStr: '20')) - } - parameters { - string(name: 'BUILD_BY', defaultValue: 'autobuild@vyos.net', description: 'Builder identifier (e.g. jrandomhacker@example.net)') - string(name: 'BUILD_VERSION', defaultValue: '1.4-rolling-' + env.TIMESTAMP, description: 'Version number (release builds only)') - booleanParam(name: 'BUILD_PUBLISH', defaultValue: true, description: 'Publish this build to downloads.vyos.io and AWS S3') - booleanParam(name: 'BUILD_SMOKETESTS', defaultValue: true, description: 'Include Smoketests in ISO image') - booleanParam(name: 'BUILD_SNAPSHOT', defaultValue: false, description: 'Upload image to AWS S3 snapshot bucket') - } - triggers { - cron('H 2 * * *') - } agent { docker { label "Docker" @@ -69,6 +53,22 @@ pipeline { reuseNode true } } + triggers { + cron('H 2 * * *') + } + parameters { + string(name: 'BUILD_BY', defaultValue: 'autobuild@vyos.net', description: 'Builder identifier (e.g. jrandomhacker@example.net)') + string(name: 'BUILD_VERSION', defaultValue: env.BASE_VERSION + 'ISO8601-TIMESTAMP', description: 'Version number (release builds only)') + booleanParam(name: 'BUILD_PUBLISH', defaultValue: true, description: 'Publish this build to downloads.vyos.io and AWS S3') + booleanParam(name: 'BUILD_SMOKETESTS', defaultValue: true, description: 'Include Smoketests in ISO image') + booleanParam(name: 'BUILD_SNAPSHOT', defaultValue: false, description: 'Upload image to AWS S3 snapshot bucket') + } + options { + disableConcurrentBuilds() + timeout(time: 150, unit: 'MINUTES') + timestamps() + buildDiscarder(logRotator(numToKeepStr: '20')) + } stages { stage('Build ISO') { when { @@ -91,12 +91,16 @@ pipeline { if (params.BUILD_SMOKETESTS) CUSTOM_PACKAGES = '--custom-package vyos-1x-smoketest' + def VYOS_VERSION = params.BUILD_BY + if (params.BUILD_VERSION == env.BASE_VERSION + 'ISO8601-TIMESTAMP') + VYOS_VERSION = env.BASE_VERSION + sh(returnStdout: true, script: 'date -u +%Y%m%d%H%M').toString().trim() + sh """ ./configure \ --build-by "${params.BUILD_BY}" \ --debian-mirror http://deb.debian.org/debian/ \ --build-type release \ - --version "${params.BUILD_VERSION}" ${CUSTOM_PACKAGES} + --version "${VYOS_VERSION}" ${CUSTOM_PACKAGES} sudo make iso """ -- cgit v1.2.3