Adosser un gestionnaire de repository Maven à Gradle

Gradle est un système de build innovant utilisant le langage dynamique Groovy pour décrire la chaîne de construction des applications, et le gestionnaire de dépendance Ivy pour gérer les librairies d’un projet.
Grâce à la richesse du contenu des repository Maven disponibles sur le marché, il est très pratique d’utiliser des repository Maven pour récupérer les librairies du projet. Pour agréger plusieurs repository Maven, vous avez besoin d’un gestionnaire de repository comme Archiva, Nexus ou même Artifactory. L’utilisation d’un tel outil permet de fournir des mécanismes de sécurité, de cache, une gestion centralisée des proxies et des fonctionnalités de recherche avancées.

L’exemple suivant (réalisé avec Gradle 0.5.2 et Archiva 1.1.3) fournit la configuration Gradle pour la récupération des librairies du projet à travers Archiva, puis la configuration pour le déploiement du livrable projet dans Archiva.

Récupération des dépendances

Il faut déclarer le point d’entrée de Archiva comme repository Maven dans lequel Gradle peut rechercher les artefacts.

  1. archivaRespositoryRootURL=http://server:8090/archiva/repository’
  2. repositoryGroupArchivaURL = « $archivaRespositoryRootURL/repository-group »
  3. dependencies {
  4. addMavenStyleRepo(‘archivaRepo’,repositoryGroupArchivaURL)
  5. compile « commons-logging:commons-logging:1.0 », « log4j:log4j:1.2.14 »
  6. }

Déploiement du livrable projet dans Archiva

Pour uploader ses artefacts, Archiva utilise le protocole webdav. Dans un premier temps, il faut récupérer une implémentation webdav et l’ajouter à une configuration nommée « deployerJars ». Ensuite, les librairies de cette configuration seront utilisées dans le deployeur Maven.

  1. snapshotsRepositoryArchivaURL= « $archivaRespositoryRootURL/snapshots »
  2. repositoryArchivaURL= « $archivaRespositoryRootURL/internal »
  3. dependencies {
  4. addConfiguration(« deployerJars »)
  5. deployerJars « org.apache.maven.wagon:wagon-webdav:1.0-beta-2@jar »
  6. }
  7. uploadLibs {
  8. uploadResolvers.addMavenDeployer(‘maven-deployer’) {
  9. addProtocolProviderJars(dependencies.resolve(‘deployerJars’))
  10. snapshotRepository(url: snapshotsRepositoryArchivaURL)
  11. repository(url: repositoryArchivaURL)
  12. }
  13. }

Exemple complet

  1. group = ‘com.zenika.example’
  2. usePlugin(‘war’)
  3. targetCompatibility = ‘1.5’
  4. sourceCompatibility = ‘1.5’
  5. archivesBaseName=‘gradle-test’
  6. archivaRespositoryRootURL=« http://server:8080/archiva/repository »
  7. snapshotsRepositoryArchivaURL= « $archivaRespositoryRootURL/snapshots »
  8. repositoryArchivaURL= « $archivaRespositoryRootURL/internal »
  9. repositoryGroupArchivaURL = « $archivaRespositoryRootURL/repository-group »
  10. version = null
  11. createTask(‘init’, overwrite: true) {
  12. if (build.taskGraph.hasTask(‘:release’)) {
  13. version = ‘1.0’
  14. } else {
  15. version = ‘1.0-SNAPSHOT’
  16. }
  17. }
  18. createTask(‘release’, dependsOn: ‘uploadLibs’) {
  19. println ‘The product has been released’
  20. }
  21. dependencies {
  22. addMavenStyleRepo(‘archivaRepo’,repositoryGroupArchivaURL)
  23. compile « commons-logging:commons-logging:1.0 », « log4j:log4j:1.2.14 »
  24. addConfiguration(« deployerJars »)
  25. deployerJars « org.apache.maven.wagon:wagon-webdav:1.0-beta-2@jar »
  26. }
  27. uploadLibs.doFirst{
  28. if (build.taskGraph.hasTask(‘:release’)) {
  29. println « Deployment into the internal repository $repositoryArchivaURL »
  30. } else {
  31. println « Deployment into the snapshots repository $snapshotsRepositoryArchivaURL »
  32. }
  33. }
  34. uploadLibs {
  35. uploadResolvers.addMavenDeployer(‘maven-deployer’) {
  36. addProtocolProviderJars(dependencies.resolve(‘deployerJars’))
  37. snapshotRepository(url: snapshotsRepositoryArchivaURL)
  38. repository(url: repositoryArchivaURL)
  39. }
  40. }

L’invocation de la commande :

 /var/local/test>gradle -q uploadLibs

déploie l’artefact produit par le projet dans l’espace “snapshots” de Archiva.
L’invocation de la commande :

 /var/local/test>gradle -q release

déploie l’artefact produit par le projet dans l’espace “internal” de Archiva.
Pour conclure, cet exemple nous fournit une première brique démontrant la très grande facilité d’intégration de Gradle dans une infrastructure Maven existante.

Laisser un commentaire

Ce site utilise Akismet pour réduire les indésirables. En savoir plus sur comment les données de vos commentaires sont utilisées.

%d blogueurs aiment cette page :