#!/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 */
}
}
}