Gradle: Push to Maven Repository
If you are a developer sharing your artifacts is a common task, that needs to be in place from the start.
In most teams and companies a Maven repository is already setup, this repository would be used mostly through CI/CD tasks enabling developers to distribute the generated artifacts.
In order to make the example possible we shall spin up a Nexus repository using Docker Compose.
First let’s create a default password and the directory containing the plugins Nexus will download. As of now the password is clear text, this will serve us for doing our first action. By resetting the admin password on nexus the file shall be removed, thus there won’t be a file with a clear text password.
mkdir nexus-data cat a-test-password > admin.password
Then onwards to the Compose file:
services: nexus: image: sonatype/nexus3 ports: - 8081:8081 environment: INSTALL4J_ADD_VM_PARAMS: "-Xms2703m -Xmx2703m -XX:MaxDirectMemorySize=2703m" volumes: - nexus-data;/nexus-data - ./admin.password:/nexus-data/admin.password volumes: nexus-data;
Let’s examine the file.
By using INSTALL4J_ADD_VM_PARAMS we override the Java command that will run the Nexus server, this way we can instruct to use more memory.
Because nexus takes too long on initialization we shall create a Docker volume. Everytime we run the compose file, the initialization will not happen from start, instead will use the results of the previous initialization. By mounting the admin password created previously we have a predefined password for the service.
By issuing the following command, the server will be up and running:
docker compose up
You can find more on Compose on the Developers Essential Guide to Docker Compose.
After some time nexus will have been initialized and running, therefore we shall proceed to our Gradle configuration.
We will keep track of the version on the gradle.properties file
version 1.0-SNAPSHOT
The build.gradle file:
plugins { id 'java' id 'maven-publish' } group 'org.example' version '1.0-SNAPSHOT' repositories { mavenCentral() } dependencies { testImplementation 'org.junit.jupiter:junit-jupiter-api:5.8.1' testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine:5.8.1' } test { useJUnitPlatform() } publishing { publications { mavenJava(MavenPublication) { groupId 'org.example' artifactId 'gradle-push' version version from components.java versionMapping { usage('java-api') { fromResolutionOf('runtimeClasspath') } usage('java-runtime') { fromResolutionResult() } } pom { name = 'gradle-push' description = 'Gradle Push to Nexus' url = 'https://github.com/gkatzioura/egkatzioura.wordpress.com.git' licenses { license { name = 'The Apache License, Version 2.0' url = 'http://www.apache.org/licenses/LICENSE-2.0.txt' } } developers { developer { id = 'John' name = 'John Doe' email = 'an-email@gmail.com' } } scm { connection = 'scm:git:https://github.com/gkatzioura/egkatzioura.wordpress.com.git' developerConnection = 'scm:git:https://github.com/gkatzioura/egkatzioura.wordpress.com.git' url = 'https://github.com/gkatzioura/egkatzioura.wordpress.com.git' } } } } repositories { maven { def releasesRepoUrl = "http://localhost:8081/repository/maven-releases/" def snapshotsRepoUrl = "http://localhost:8081/repository/maven-snapshots/" url = version.endsWith('SNAPSHOT') ? snapshotsRepoUrl : releasesRepoUrl credentials { username "admin" password "a-test-password" } } } }
The plugin to be used is the maven-publish plugin. If we examine the file, we identify that the plugin generates a pom maven file which shall be used in order to execute the deploy command to Nexus. The repositories are configured on the repositories section including the nexus users we defined previously. Whether the version is a SNAPSHOT or a release the corresponding repository endpoint will be picked. As we see clear text password is used. On the next blog we will examine how we can avoid that.
Now it is sufficient to run
gradle publish
This will deploy the binary to the snapshot repository.
You can find the source code on GitHub.
Published on Java Code Geeks with permission by Emmanouil Gkatziouras, partner at our JCG program. See the original article here: Gradle: Push to Maven Repository Opinions expressed by Java Code Geeks contributors are their own. |