Upated to sqential execution of versions
All checks were successful
LXC-ImageBuilder/Ubuntu/pipeline/head This commit looks good
All checks were successful
LXC-ImageBuilder/Ubuntu/pipeline/head This commit looks good
This commit is contained in:
80
Jenkinsfile
vendored
80
Jenkinsfile
vendored
@@ -1,3 +1,6 @@
|
|||||||
|
String[] ImgReleaseList = ['bionic', 'focal']
|
||||||
|
String[] ImgVariantList = ['Default-minmal', 'Default-default']
|
||||||
|
|
||||||
pipeline {
|
pipeline {
|
||||||
agent { label 'LXCBuilder' }
|
agent { label 'LXCBuilder' }
|
||||||
parameters {
|
parameters {
|
||||||
@@ -21,57 +24,38 @@ pipeline {
|
|||||||
sh '''mkdir $WORKSPACE/REL'''
|
sh '''mkdir $WORKSPACE/REL'''
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
stage("Image Configs") {
|
stage('Image Configs'){
|
||||||
matrix {
|
steps{
|
||||||
axes {
|
script{
|
||||||
axis {
|
for(ImgRelease in ImgReleaseList){
|
||||||
name 'ImgRelease'
|
for(ImgVariant in ImgVariantList){
|
||||||
values 'bionic', 'focal'
|
|
||||||
}
|
|
||||||
axis {
|
|
||||||
name 'ImgVariant'
|
|
||||||
values 'Default-minmal', 'Default-default'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
//Exclude unwanted conbinatinations
|
|
||||||
excludes {
|
|
||||||
exclude {
|
|
||||||
axis {
|
|
||||||
name 'ImgRelease'
|
|
||||||
values 'bionic'
|
|
||||||
}
|
|
||||||
axis {
|
|
||||||
name 'ImgVariant'
|
|
||||||
//use notValues to invert
|
|
||||||
notValues 'Default-default'
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
stages {
|
|
||||||
stage('Build image') {
|
|
||||||
when {
|
|
||||||
//ImgTypeTest
|
//ImgTypeTest
|
||||||
anyOf {
|
if (env.BuildDefault == 'true' && (ImgVariant).startsWith('Default-')) {
|
||||||
allOf {
|
BuildThis = true
|
||||||
expression { return (env.ImgVariant).startsWith('Default-') }
|
} else if (env.BuildExtra == 'true' && (ImgVariant).startsWith('Extra-')) {
|
||||||
environment name: 'BuildDefault', value: 'true'
|
BuildThis = true
|
||||||
}
|
} else {
|
||||||
allOf {
|
BuildThis = false
|
||||||
expression { return (env.ImgVariant).startsWith('Extra-') }
|
|
||||||
environment name: 'BuildExtra', value: 'true'
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
//Exclude unwanted conbinatinations
|
||||||
steps {
|
if (ImgRelease == 'bionic' && ImgVariant != 'Default-default' ){
|
||||||
// Build script
|
BuildThis = false
|
||||||
catchError(buildResult: 'SUCCESS', stageResult: 'FAILURE') {
|
|
||||||
sh '''echo "$(date) Do Build for $ImgRelease - $ImgVariant"
|
|
||||||
ImgVariantName=${ImgVariant#Default-} && ImgVariantName=${ImgVariantName#Extra-}
|
|
||||||
sudo $WORKSPACE/distrobuilder build-lxc Ubuntu.yaml $WORKSPACE/REL/$ImgRelease-$ImgVariant/ -o image.release=$ImgRelease -o image.variant=$ImgVariantName
|
|
||||||
sudo chown jenkins:jenkins -R $WORKSPACE/REL
|
|
||||||
mv $WORKSPACE/REL/$ImgRelease-$ImgVariant/rootfs.tar.xz Ubuntu-$ImgRelease-$ImgVariant.tar.xz
|
|
||||||
'''
|
|
||||||
}
|
}
|
||||||
|
//Check if this combinations shoud be build
|
||||||
|
if (BuildThis == true) {
|
||||||
|
env.ImgRelease = ImgRelease
|
||||||
|
env.ImgVariant = ImgVariant
|
||||||
|
stage('Build image') {
|
||||||
|
catchError(buildResult: 'SUCCESS', stageResult: 'FAILURE') {
|
||||||
|
sh '''echo "$(date) Do Build for $ImgRelease - $ImgVariant"
|
||||||
|
ImgVariantName=${ImgVariant#Default-} && ImgVariantName=${ImgVariantName#Extra-}
|
||||||
|
sudo $WORKSPACE/distrobuilder build-lxc Ubuntu.yaml $WORKSPACE/REL/$ImgRelease-$ImgVariant/ -o image.release=$ImgRelease -o image.variant=$ImgVariantName
|
||||||
|
sudo chown jenkins:jenkins -R $WORKSPACE/REL
|
||||||
|
mv $WORKSPACE/REL/$ImgRelease-$ImgVariant/rootfs.tar.xz Ubuntu-$ImgRelease-$ImgVariant.tar.xz
|
||||||
|
'''
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user