Résumé
Liste des changements à apporter à l’environnement de build pour passer de Gradle 4.5 à Maven 3.8.
Ticket JIRA et commit
Avant de toucher à un module, il faut créer un ticket JIRA avec comme titre :
[Nom de l’app] - Migration Maven
Après chaque portage, le message de commit doit être le suivant :
"feat: #<NUM_TICKET>, migration Maven"
Portage
pom.xml
Pour un module SANS création de JARs
Reprendre le squelette ci-dessous, adapter en suivant les commentaires.
<?xml version="1.0" encoding="UTF-8"?> <project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>io.edifice</groupId> <artifactId>edifice-parent</artifactId> <version>1.0</version> </parent> <groupId>fr.wseduc</groupId><!-- Vient de gradle.properties > modowner --> <artifactId>web-utils</artifactId><!-- Vient de gradle.properties > modname --> <version>3.0-b2school-SNAPSHOT</version><!-- Vient de gradle.properties > version --> <repositories> <repository> <id>ode</id> <name>ODE Repository</name> <url>https://maven.opendigitaleducation.com/nexus/content/groups/public</url> </repository> </repositories> <properties><!-- Reporter les versions des dépendances de gradle.properties > --> <jacksonDatabindVersion>2.15.2</jacksonDatabindVersion> </properties> <dependencies><!-- Reporter les dépendances qui étaient dans build.gradle > dependencies --> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>${jacksonDatabindVersion}</version> <scope>provided</scope> </dependency> </dependencies> </project>
Pour un module AVEC création de JARs (.jar, -fat.jar, -test.jar, -deployment.jar)
Reprendre le squelette ci-desous, adapter en suivant les commentaires.
<?xml version="1.0" encoding="UTF-8"?> <project xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd" xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> <modelVersion>4.0.0</modelVersion> <parent> <groupId>io.edifice</groupId> <artifactId>app-parent</artifactId> <version>1.0</version> </parent> <groupId>net.atos</groupId><!-- Vient de gradle.properties > modowner --> <artifactId>actualites</artifactId><!-- Vient de gradle.properties > modname --> <version>2.0-b2school-SNAPSHOT</version> <!-- Vient de gradle.properties > version --> <scm><!-- Adapter avec l'url du repertoire (github, gitlab...) --> <connection>scm:git:https://github.com/OPEN-ENT-NG/actualites.git</connection> <developerConnection>scm:git:https://github.com/OPEN-ENT-NG/actualites.git</developerConnection> <url>https://github.com/OPEN-ENT-NG/actualites</url> </scm> <repositories> <repository> <id>ode</id> <name>ODE Repository</name> <url>https://maven.opendigitaleducation.com/nexus/content/groups/public</url> </repository> </repositories> <properties><!-- Reporter les versions des dépendances de gradle.properties --> <web-utils.version>3.0-b2school-SNAPSHOT</web-utils.version> </properties> <dependencies><!-- Reporter les dépendances qui étaient dans build.gradle > dependencies --> <dependency> <groupId>io.vertx</groupId> <artifactId>vertx-core</artifactId> <version>${vertxVersion}</version> <scope>provided</scope> </dependency> <dependency> <groupId>fr.wseduc</groupId> <artifactId>web-utils</artifactId> <version>${web-utils.version}</version> <scope>compile</scope> </dependency> </dependencies> </project>
docker-compose.yml
Remplacer le service gradle par le service maven
tel que décrit plus bas.
services: maven: image: maven:3.8.6-jdk-8 user: "$DEFAULT_DOCKER_USER" working_dir: /usr/src/maven volumes: - ./:/usr/src/maven - ~/.m2:/var/maven/.m2 environment: MAVEN_CONFIG: /var/maven/.m2
build.sh
Ajouter au début du fichier la variable MVN_OPTS tel que décrit ci-dessous.
MVN_OPTS="-Duser.home=/var/maven"
Remplacer les appels au service gradle par des appels au service maven tel que ci-dessous.
Avant:
docker-compose run --rm -u "$USER_UID:$GROUP_GID" gradle gradle clean
Après :
docker compose run --rm maven mvn $MVN_OPTS clean
Ajouter les méthodes init
, install
et test
et les ajouter à la liste des options supportées (la méthode install
remplace buildGradle
)
init() { me=`id -u`:`id -g` echo "DEFAULT_DOCKER_USER=$me" > .env } ... install () { docker compose run --rm maven mvn $MVN_OPTS install -DskipTests } test () { docker compose run --rm maven mvn $MVN_OPTS test } ... for param in "$@" do case $param in init) init ;; ... install) install ;; test) test ;; ...
Modifier la méthode publish pour qu’elle soit équivalente à celle écrite ci-dessous :
publish() { version=`docker compose run --rm maven mvn $MVN_OPTS help:evaluate -Dexpression=project.version -q -DforceStdout` level=`echo $version | cut -d'-' -f3` case "$level" in *SNAPSHOT) export nexusRepository='snapshots' ;; *) export nexusRepository='releases' ;; esac docker compose run --rm maven mvn -DrepositoryId=ode-$nexusRepository -DskiptTests -Dmaven.test.skip=true --settings /var/maven/.m2/settings.xml deploy }
Exemple complet :
#!/bin/bash MVN_OPTS="-Duser.home=/var/maven" init() { me=`id -u`:`id -g` echo "DEFAULT_DOCKER_USER=$me" > .env } clean () { docker compose run --rm maven mvn $MVN_OPTS clean } install () { docker compose run --rm maven mvn $MVN_OPTS install -DskipTests } test () { docker compose run --rm maven mvn $MVN_OPTS test } publish() { version=`docker compose run --rm maven mvn $MVN_OPTS help:evaluate -Dexpression=project.version -q -DforceStdout` level=`echo $version | cut -d'-' -f3` case "$level" in *SNAPSHOT) export nexusRepository='snapshots' ;; *) export nexusRepository='releases' ;; esac docker compose run --rm maven mvn -DrepositoryId=ode-$nexusRepository -DskiptTests -Dmaven.test.skip=true --settings /var/maven/.m2/settings.xml deploy } for param in "$@" do case $param in init) init ;; clean) clean ;; install) install ;; test) test ;; publish) publish ;; *) echo "Invalid argument : $param" esac if [ ! $? -eq 0 ]; then exit 1 fi done
Jenkinsfile
Ajouter l'étape “Initialization”.
Au tout premier argument du build.sh, ajouter le paramètre init afin d’initialiser le fichier .env
Avant :
#!/usr/bin/env groovy pipeline { agent any stages { stage('Build') { steps { checkout scm sh './build.sh clean install publish' } } } }
Après :
#!/usr/bin/env groovy pipeline { agent any stages { stage("Initialization") { steps { script { def version = sh(returnStdout: true, script: 'docker compose run --rm maven mvn $MVN_OPTS help:evaluate -Dexpression=project.version -q -DforceStdout') buildName "${env.GIT_BRANCH.replace("origin/", "")}@${version}" } } } stage('Build') { steps { checkout scm sh './build.sh init clean install publish' } } } }
.gitignore
Ajouter les lignes suivantes
.env target dependency-reduced-pom.xml
0 commentaires