Séparation des jobs d'empaquetage en 2 phases
This commit is contained in:
@ -109,7 +109,6 @@ pipeline {
|
||||
|
||||
// Pour chaque construction de paquets...
|
||||
result.each { r ->
|
||||
|
||||
// On essaye de trouver un template de VM compatible
|
||||
// avec la distribution cible de la construction
|
||||
def vmTemplate = findMatchingVMTemplate(r.distrib)
|
||||
@ -120,24 +119,19 @@ pipeline {
|
||||
|
||||
// Pour chaque paquets construits...
|
||||
r.packages.each { p ->
|
||||
def packageName = new File(p).getName()
|
||||
def packageFullName = new File(p).getName()
|
||||
def packageRepository = r.distrib.split('-')[1] + '-' + r.env
|
||||
def packageNameParts = packageFullName.split('_')
|
||||
def packageName = packageNameParts[0]
|
||||
def packageVersion = packageNameParts[1]
|
||||
|
||||
stage("Test package '${packageName}' installation") {
|
||||
try {
|
||||
// On démarre une nouvelle VM et on lance l'installation du paquet publié
|
||||
testPackageInstallation(vmTemplate, r.distrib, r.env, packageName)
|
||||
} catch(e) {
|
||||
currentBuild.result = 'UNSTABLE'
|
||||
rocketSend (
|
||||
avatar: 'https://jenkins.cadol.es/static/b5f67753/images/headshot.png',
|
||||
message: """
|
||||
[Installation du paquet `${packageName}` échouée sur `${vmTemplate}`](${env.RUN_DISPLAY_URL})
|
||||
|
||||
@${env.sender_login}
|
||||
""".stripIndent(),
|
||||
rawMessage: true
|
||||
)
|
||||
error("Installation du paquet `${packageName}` échouée.")
|
||||
}
|
||||
build job: 'Test de paquet Debian', wait: false, parameters: [
|
||||
[$class: 'StringParameterValue', name: 'packageName', value: packageName],
|
||||
[$class: 'StringParameterValue', name: 'packageVersion', value: packageVersion],
|
||||
[$class: 'StringParameterValue', name: 'packageRepository', value: packageRepository],
|
||||
[$class: 'StringParameterValue', name: 'vmTemplate', value: vmTemplate]
|
||||
]
|
||||
}
|
||||
}
|
||||
}
|
||||
@ -166,21 +160,4 @@ def findMatchingVMTemplate(String distrib) {
|
||||
'eole-2.6.2': 'eolebase-2.6.2-cadoles'
|
||||
]
|
||||
return vmTemplatesMap.get(distrib, null)
|
||||
}
|
||||
|
||||
// Cette fonction démarre une nouvelle VM, configure les dépôts tiers pour ajouter
|
||||
// celui de Cadoles correspondant à la cible du paquet et tente d'installer celui ci.
|
||||
def testPackageInstallation(String vmTemplate, String distrib, String env, String packageName) {
|
||||
def version = distrib.split('-')[1]
|
||||
def packageNameParts = packageName.split('_')
|
||||
nebula.runInNewVM([
|
||||
vmTemplate: vmTemplate,
|
||||
script: """
|
||||
set -xeo pipefail
|
||||
wget -qO - https://vulcain.cadoles.com/cadoles.gpg | apt-key add -
|
||||
echo 'deb https://vulcain.cadoles.com ${version}-${env} main' > /etc/apt/sources.list.d/${version}-${env}.list
|
||||
apt-get update -y
|
||||
apt-get install -y ${packageNameParts[0]}=${packageNameParts[1]}
|
||||
"""
|
||||
])
|
||||
}
|
Reference in New Issue
Block a user