Gradle - wdrożenie

Gradle oferuje kilka sposobów wdrażania repozytoriów artefaktów kompilacji. Podczas wdrażania sygnatur dla artefaktów w repozytorium Maven zechcesz również podpisać opublikowany plik POM.

Korzystanie z wtyczki Maven-Publishing

maven-publishwtyczka, która jest domyślnie dostarczana przez Gradle. Służy do publikowania skryptu gradle. Spójrz na poniższy kod.

apply plugin: 'java'
apply plugin: 'maven-publish'

publishing {
   publications {
      mavenJava(MavenPublication) {
         from components.java
      }
   }

   repositories {
      maven {
         url "$buildDir/repo"
      }
   }
}

Istnieje kilka opcji publikowania, gdy Java i maven-publishwtyczka jest stosowana. Spójrz na następujący kod, wdroży projekt w zdalnym repozytorium.

apply plugin: 'groovy'
apply plugin: 'maven-publish'

group 'workshop'
version = '1.0.0'

publishing {
   publications {
      mavenJava(MavenPublication) { 
         from components.java 
      }
   }
	
   repositories {
      maven {
          default credentials for a nexus repository manager
         credentials {
            username 'admin'
            password 'admin123'
         }
         // url to the releases maven repository
            url "http://localhost:8081/nexus/content/repositories/releases/"
      }
   }
}

Konwersja projektu z Maven do Gradle

Istnieje specjalne polecenie konwersji Apache Maven pom.xml pliki do plików kompilacji Gradle, jeśli wszystkie używane wtyczki Maven są znane w tym zadaniu.

W tej sekcji następujące pom.xmlKonfiguracja maven zostanie przekonwertowana na projekt Gradle. Przyjrzyj się temu.

<project xmlns = "http://maven.apache.org/POM/4.0.0" 
   xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation = "http://maven.apache.org/POM/4.0.0
   http://maven.apache.org/xsd/maven-4.0.0.xsd">
	
   <modelVersion>4.0.0</modelVersion>
   <groupId>com.example.app</groupId>
   <artifactId>example-app</artifactId>
   <packaging>jar</packaging>
   
   <version>1.0.0-SNAPSHOT</version>
	
   <dependencies>
      <dependency>
         <groupId>junit</groupId>
         <artifactId>junit</artifactId>

         <version>4.11</version>
         <scope>test</scope>
      </dependency>
   </dependencies>
	
</project>

Możesz użyć następującego polecenia w wierszu polecenia, które spowoduje następującą konfigurację Gradle.

C:\> gradle init --type pom

Plik init zadanie zależy od zadania opakowania, więc zostanie utworzona otoka Gradle.

Wynikowy build.gradle plik wygląda podobnie do tego -

apply plugin: 'java'
apply plugin: 'maven'

group = 'com.example.app'
version = '1.0.0-SNAPSHOT'

description = """"""

sourceCompatibility = 1.5
targetCompatibility = 1.5

repositories {
   maven { url "http://repo.maven.apache.org/maven2" }
}

dependencies {
   testCompile group: 'junit', name: 'junit', version:'4.11'
}