diff options
author | Christian Poessinger <christian@poessinger.com> | 2020-06-20 14:36:09 +0200 |
---|---|---|
committer | Christian Poessinger <christian@poessinger.com> | 2020-06-20 23:11:56 +0200 |
commit | 7ab2724c338f1372d0ef65f0ac3600282d13ace0 (patch) | |
tree | 8b989c0e29c28b433de6b0c13d81eaa5cfd7a393 | |
parent | 3656075d2736b59b857ca443cb77c2a6ea2ac822 (diff) | |
download | vyos-build-7ab2724c338f1372d0ef65f0ac3600282d13ace0.tar.gz vyos-build-7ab2724c338f1372d0ef65f0ac3600282d13ace0.zip |
Jenkins: initial support for shared build libraries
Instead of writing the same code over and over again, place the common parts
into a Jenkins Library which is then consumed by every individual build Job.
This not only makes it less complex, but also increases maintainability by
several magnitudes.
-rw-r--r-- | packages/netfilter/Jenkinsfile | 93 | ||||
-rw-r--r-- | vars/README.md | 6 | ||||
-rw-r--r-- | vars/getGitBranchName.groovy | 21 | ||||
-rw-r--r-- | vars/getGitRepoName.groovy | 20 | ||||
-rw-r--r-- | vars/getGitRepoURL.groovy | 20 | ||||
-rw-r--r-- | vars/isCustomBuild.groovy | 26 | ||||
-rw-r--r-- | vars/setDescription.groovy | 38 |
7 files changed, 160 insertions, 64 deletions
diff --git a/packages/netfilter/Jenkinsfile b/packages/netfilter/Jenkinsfile index 9554f6e3..1af7dec5 100644 --- a/packages/netfilter/Jenkinsfile +++ b/packages/netfilter/Jenkinsfile @@ -14,52 +14,8 @@ // along with this program. If not, see <http://www.gnu.org/licenses/>. @NonCPS - -def getGitBranchName() { - def branch = scm.branches[0].name - return branch.split('/')[-1] -} - -def getGitRepoURL() { - return scm.userRemoteConfigs[0].url -} - -def getGitRepoName() { - return getGitRepoURL().split('/').last() -} - -// Returns true if this is a custom build launched on any project fork. -// Returns false if this is build from git@github.com:vyos/<reponame>. -// <reponame> can be e.g. vyos-1x.git or vyatta-op.git -def isCustomBuild() { - // GitHub organisation base URL - def gitURI = 'git@github.com:vyos/' + getGitRepoName() - def httpURI = 'https://github.com/vyos/' + getGitRepoName() - - return !((getGitRepoURL() == gitURI) || (getGitRepoURL() == httpURI)) || env.CHANGE_ID -} - -def setDescription() { - def item = Jenkins.instance.getItemByFullName(env.JOB_NAME) - - // build up the main description text - def description = "" - description += "<h2>VyOS individual package build: " + getGitRepoName().replace('.git', '') + "</h2>" - - if (isCustomBuild()) { - description += "<p style='border: 3px dashed red; width: 50%;'>" - description += "<b>Build not started from official Git repository!</b><br>" - description += "<br>" - description += "Repository: <font face = 'courier'>" + getGitRepoURL() + "</font><br>" - description += "Branch: <font face = 'courier'>" + getGitBranchName() + "</font><br>" - description += "</p>" - } else { - description += "Sources taken from Git branch: <font face = 'courier'>" + getGitBranchName() + "</font><br>" - } - - item.setDescription(description) - item.save() -} +/* Using a version specifier library, use 'current' branch */ +@Library('vyos-build@current') /* Only keep the 10 most recent builds. */ def projectProperties = [ @@ -71,20 +27,20 @@ setDescription() node('Docker') { stage('Define Agent') { - script { - // create container name on demand - def branchName = getGitBranchName() - // Adjust PR target branch name so we can re-map it to the proper - // Docker image. CHANGE_ID is set only for pull requests, so it is - // safe to access the pullRequest global variable - if (env.CHANGE_ID) { - branchName = "${env.CHANGE_TARGET}".toLowerCase() - } - if (branchName.equals("master")) { - branchName = "current" - } - env.DOCKER_IMAGE = "vyos/vyos-build:" + branchName - } + script { + // create container name on demand + def branchName = getGitBranchName() + // Adjust PR target branch name so we can re-map it to the proper + // Docker image. CHANGE_ID is set only for pull requests, so it is + // safe to access the pullRequest global variable + if (env.CHANGE_ID) { + branchName = "${env.CHANGE_TARGET}".toLowerCase() + } + if (branchName.equals("master")) { + branchName = "current" + } + env.DOCKER_IMAGE = "vyos/vyos-build:" + branchName + } } } @@ -101,13 +57,20 @@ pipeline { CHANGESET_DIR = "**/${env.BASE_DIR}*" } options { + disableConcurrentBuilds() timeout(time: 60, unit: 'MINUTES') timestamps() } stages { stage('Fetch') { when { - changeset "${env.CHANGESET_DIR}" + beforeOptions true + beforeAgent true + anyOf { + changeset "${env.CHANGESET_DIR}" + triggeredBy 'TimerTrigger' + triggeredBy cause: "UserIdCause" + } } steps { script { @@ -190,9 +153,11 @@ pipeline { deleteDir() } success { - // archive *.deb artifact on custom builds, deploy to repo otherwise - if ( isCustomBuild()) { - archiveArtifacts artifacts: '**/*.deb', allowEmptyArchive: true + script { + // archive *.deb artifact on custom builds, deploy to repo otherwise + if ( isCustomBuild()) { + archiveArtifacts artifacts: '**/*.deb', allowEmptyArchive: true + } } } } diff --git a/vars/README.md b/vars/README.md new file mode 100644 index 00000000..ca2f821f --- /dev/null +++ b/vars/README.md @@ -0,0 +1,6 @@ +# Jenkins Build Library + +Instead of writing the same code over and over again, place the common +parts into a Jenkins Library which is then consumed by every individual +build Job. This not only makes it less complex, it also increases +maintainability by several magnitudes. diff --git a/vars/getGitBranchName.groovy b/vars/getGitBranchName.groovy new file mode 100644 index 00000000..133734da --- /dev/null +++ b/vars/getGitBranchName.groovy @@ -0,0 +1,21 @@ +#!/usr/bin/env groovy +// Copyright (C) 2020 VyOS maintainers and contributors +// +// This program is free software; you can redistribute it and/or modify +// in order to easy exprort images built to "external" world +// it under the terms of the GNU General Public License version 2 or later as +// published by the Free Software Foundation. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see <http://www.gnu.org/licenses/>. + +def call() { + def branch = scm.branches[0].name + return branch.split('/')[-1] +} + diff --git a/vars/getGitRepoName.groovy b/vars/getGitRepoName.groovy new file mode 100644 index 00000000..058e4ff5 --- /dev/null +++ b/vars/getGitRepoName.groovy @@ -0,0 +1,20 @@ +#!/usr/bin/env groovy +// Copyright (C) 2020 VyOS maintainers and contributors +// +// This program is free software; you can redistribute it and/or modify +// in order to easy exprort images built to "external" world +// it under the terms of the GNU General Public License version 2 or later as +// published by the Free Software Foundation. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see <http://www.gnu.org/licenses/>. + +def call() { + return getGitRepoURL().split('/').last() +} + diff --git a/vars/getGitRepoURL.groovy b/vars/getGitRepoURL.groovy new file mode 100644 index 00000000..d36b48e6 --- /dev/null +++ b/vars/getGitRepoURL.groovy @@ -0,0 +1,20 @@ +#!/usr/bin/env groovy +// Copyright (C) 2020 VyOS maintainers and contributors +// +// This program is free software; you can redistribute it and/or modify +// in order to easy exprort images built to "external" world +// it under the terms of the GNU General Public License version 2 or later as +// published by the Free Software Foundation. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see <http://www.gnu.org/licenses/>. + +def call() { + return scm.userRemoteConfigs[0].url +} + diff --git a/vars/isCustomBuild.groovy b/vars/isCustomBuild.groovy new file mode 100644 index 00000000..301fdd42 --- /dev/null +++ b/vars/isCustomBuild.groovy @@ -0,0 +1,26 @@ +#!/usr/bin/env groovy +// Copyright (C) 2020 VyOS maintainers and contributors +// +// This program is free software; you can redistribute it and/or modify +// in order to easy exprort images built to "external" world +// it under the terms of the GNU General Public License version 2 or later as +// published by the Free Software Foundation. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see <http://www.gnu.org/licenses/>. + +def call() { + // Returns true if this is a custom build launched on any project fork. + // Returns false if this is build from git@github.com:vyos/<reponame>. + // <reponame> can be e.g. vyos-1x.git or vyatta-op.git + // GitHub organisation base URL + def gitURI = 'git@github.com:vyos/' + getGitRepoName() + def httpURI = 'https://github.com/vyos/' + getGitRepoName() + + return !((getGitRepoURL() == gitURI) || (getGitRepoURL() == httpURI)) || env.CHANGE_ID +} diff --git a/vars/setDescription.groovy b/vars/setDescription.groovy new file mode 100644 index 00000000..a503bc28 --- /dev/null +++ b/vars/setDescription.groovy @@ -0,0 +1,38 @@ +#!/usr/bin/env groovy +// Copyright (C) 2020 VyOS maintainers and contributors +// +// This program is free software; you can redistribute it and/or modify +// in order to easy exprort images built to "external" world +// it under the terms of the GNU General Public License version 2 or later as +// published by the Free Software Foundation. +// +// This program is distributed in the hope that it will be useful, +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +// GNU General Public License for more details. +// +// You should have received a copy of the GNU General Public License +// along with this program. If not, see <http://www.gnu.org/licenses/>. + +def call() { + def item = Jenkins.instance.getItemByFullName(env.JOB_NAME) + + // build up the main description text + def description = "" + description += "<h2>VyOS individual package build: " + getGitRepoName().replace('.git', '') + "</h2>" + + if (isCustomBuild()) { + description += "<p style='border: 3px dashed red; width: 50%;'>" + description += "<b>Build not started from official Git repository!</b><br>" + description += "<br>" + description += "Repository: <font face = 'courier'>" + getGitRepoURL() + "</font><br>" + description += "Branch: <font face = 'courier'>" + getGitBranchName() + "</font><br>" + description += "</p>" + } else { + description += "Sources taken from Git branch: <font face = 'courier'>" + getGitBranchName() + "</font><br>" + } + + item.setDescription(description) + item.save() +} + |