Jenkins peut rapidement devenir une usine à jobs. Sans être nécessairement Netflix aux 1001 projets, l’application de certains paradigmes peut faire augmenter significativement le nombre de jobs.
Nous allons voir comment le plugin Job DSL
peut résoudre cette problématique.
L’application de certains paradigmes peut faire augmenter significativement le nombre de jobs:
compilation
, test
et deployment
pour arriver à des projets associés à N jobs.Suivant le dernier point, 10 projets vont générer au moins 30 jobs. Enjoy.
L’idée face à cette configuration est de maintenir un pool de job type maitrisé et de ne pas multiplier les projets avec des configurations spécifiques.
Il reste tout de même la problématique de création et de maintenance des jobs. Même si créer un job à partir de reste simple (quoi que source du syndrome du copier/coller), configurer le tout sous la forme d’un pipeline reste fastidieux. Vient ensuite la maintenance de ces jobs où la modification d’un job type va toucher l’ensemble des jobs de ce type. Sans évoquer l’ajout d’un nouveau job type s’intercalant entre deux types.
Il existe plusieurs moyens qui apportent des solutions à des niveaux différents:
Job DSL Plugin
The job-dsl-plugin allows the programmatic creation of projects using a DSL. Pushing job creation into a script allows you to automate and standardize your Jenkins installation, unlike anything possible before.
Le tout exprimé dans le langage Groovy qui propose des fonctionnalités poussées pour créer des DSL.
Par exemple le script ci-dessous (tiré de la page du plugin) permet de générer autant de job qu’il existe de branche sur le projet GitHub:
Clair et concise, la configuration tient dans 1/3 d’écran avec juste ce qu’il y a à configurer.
Obviously, un jenkins (au moins le LTS) et le Job DSL Plugin
.
Je vais prendre ici le cas le plus simple, 3 job types différents : compilation
, test
, package
(pour s’abstraire du déploiement).
L’objectif premier est de qualifier ces types et de définir la structure décrivant ces jobs.
Nous avons donc une liste de projets qui sont caractérisés par un identifiant, un nom et une url scm.
compilation
est un job maven qui lance une compilation.test
est un job maven qui lance les tests.package
est un freestyle job qui package l’artefact maven et copie le tout dans /dev/null
Freestyle project
que je nomme Generate Jobs
Process Job DSLs
.
Première option intéressante, le script peut être mis directement dans la configuration du job ou stocké sur le filesystem suite, par exemple, à un clone de son repository.J’utilise pour cela le JsonSlurper: JSON slurper parses text or reader content into a data structure of lists and maps.
Les 2 projects ont respectivement leurs 3 jobs de définis avec leurs relations downstream
.
projectScm
projectScm
est la factorisation du bloc de configuration du SCM ci-dessous qui serait autrement à répeter dans chaque job:
J’ai donc sorti ce bloc que j’ai mis dans une closure Groovy pour pouvoir l’utiliser dans la DSL Jenkins. Il est cependant nécessaire de définir par délégation le scope d’évalutation de cette closure qui est mis au scope du DSL Jenkins en cours d’execution. Pour plus d’information voir cet excellent article: Groovy Closures: this, owner, delegate Let’s Make a DSL.
Je crée une vue de type Pipeline que je mets en fin d’itération
En 55 lignes de code et 12 lignes de fichier de description, j’ai pu définir un process de génération d’un pipeline de projet qui dans notre exemple a créé 6 jobs et 2 vues de type pipeline.
Dans le prochain article, j’utiliserai un Job dsl pour générer les jobs de release.