#!/usr/bin/env groovy // Copyright (C) 2018 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 . @NonCPS def getGitBranchName() { return scm.branches[0].name } def getGitRepoURL() { return scm.userRemoteConfigs[0].url } // Returns true if this is a custom build launched on any project fork, // returns false if this is build from git@github.com:vyos/vyos-build.git def isCustomBuild() { def gitURI = "git@github.com:vyos/vyos-build.git" def httpURI = "https://github.com/vyos/vyos-build.git" return ! ((getGitRepoURL() == gitURI) || (getGitRepoURL() == httpURI)) } def setDescription() { def item = Jenkins.instance.getItemByFullName(env.JOB_NAME) // build up the main description text def description = "" description += "

Build VyOS ISO image

" description += "All required Vyatta/VyOS packages are build from source prior to assembling the ISO." if (isCustomBuild()) { description += "

" description += "Build not started from official Git repository!
" description += "
" description += "Repository: " + getGitRepoURL() + "
" description += "Branch: " + getGitBranchName() + "
" description += "

" } else { description += "Sources taken from Git branch: " + getGitBranchName() + "
" } item.setDescription(description) item.save() } /* Only keep the 10 most recent builds. */ def projectProperties = [ [$class: 'BuildDiscarderProperty',strategy: [$class: 'LogRotator', numToKeepStr: '1']], ] properties(projectProperties) setDescription() pipeline { options { disableConcurrentBuilds() timeout(time: 4, unit: 'HOURS') parallelsAlwaysFailFast() } agent { dockerfile { filename 'Dockerfile' label 'jessie-amd64' dir 'docker' args '--privileged --sysctl net.ipv6.conf.lo.disable_ipv6=0 -e GOSU_UID=1006 -e GOSU_GID=1006' } } stages { stage('VyOS Packages') { steps { script { def build = [:] // get a list of available package from scripts/build-packages packageList = sh( script: "scripts/build-packages -l | grep '*' | sed -e 's/ \\* //'", returnStdout: true ).split("\r?\n") packageList.each { pkg -> skipList = ['vyos-kernel', 'vyos-wireguard', 'vyos-accel-ppp'] if (pkg in skipList) { return } // add each object from 'packageList' to the 'build' array build[pkg] = { // we're already in the script{} block, so do our advanced stuff here sh( script: "scripts/build-packages -vvv -b ${pkg}", returnStdout: true ) } } // Still within the 'Script' block, run the parallel array object parallel build } } } stage('Kernel') { steps { sh "scripts/build-packages -vvv -b vyos-kernel" } } stage('Kernel Modules') { steps { script { def build = [:] kernelModules = ['vyos-wireguard', 'vyos-accel-ppp'] kernelModules.each { pkg -> // add each object from 'packageList' to the 'build' array build[pkg] = { // we're already in the script{} block, so do our advanced stuff here sh( script: "scripts/build-packages -vvv -b ${pkg}", returnStdout: true ) } } // Still within the 'Script' block, run the parallel array object parallel build } } } stage('Intel Drivers') { steps { sh "KSRC=\$(pwd)/packages/vyos-kernel scripts/build-intel-drivers" } } stage('List Packages') { steps { sh "find packages/ -maxdepth 1 -type f -print0 | xargs -0r ls" } } stage('ISO Image') { steps { sh ''' #!/bin/sh # we do not want to fetch VyOS packages from the mirror, # we rather prefer all build by ourself! sed -i '/vyos_repo_entry/d' scripts/live-build-config # remove debug packages rm -f packages/*-dbg_*.deb # Configure the ISO ./configure --build-by="autobuild@vyos.net" --debian-mirror="http://ftp.us.debian.org/debian/" # Finally build our ISO sudo make iso ''' } } } post { always { archiveArtifacts artifacts: 'build/build.log', fingerprint: true } success { archiveArtifacts artifacts: 'build/vyos*.iso', fingerprint: true } cleanup { echo 'One way or another, I have finished' // the 'build' directory got elevated permissions during the build // cdjust permissions so it can be cleaned up by the regular user sh ''' #!/bin/bash if [ -d build ]; then sudo chmod -R 777 build/ fi ''' deleteDir() /* cleanup our workspace */ } } }