From 25760ba174faee050ba3459627f999eb6b164214 Mon Sep 17 00:00:00 2001 From: Manuel Fuchs Date: Mon, 15 Mar 2021 12:08:04 +0100 Subject: [PATCH 1/3] Add heroku/maven README --- buildpacks/maven/CHANGELOG.md | 1 + buildpacks/maven/README.md | 85 ++++++++++++++++++++++++++++++++++- 2 files changed, 85 insertions(+), 1 deletion(-) diff --git a/buildpacks/maven/CHANGELOG.md b/buildpacks/maven/CHANGELOG.md index df4b92b4..9ec95a7b 100644 --- a/buildpacks/maven/CHANGELOG.md +++ b/buildpacks/maven/CHANGELOG.md @@ -3,6 +3,7 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/), and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html). ## [Unreleased] +* Add documentation to `README.md` ## [0.2.2] 2021/02/23 diff --git a/buildpacks/maven/README.md b/buildpacks/maven/README.md index aa4ee21c..052b188f 100644 --- a/buildpacks/maven/README.md +++ b/buildpacks/maven/README.md @@ -1,4 +1,87 @@ -# Heroku Cloud Native Maven Buildpack +# Heroku Cloud Native Maven Buildpack +[![CircleCI](https://circleci.com/gh/heroku/buildpacks-jvm/tree/main.svg?style=shield)](https://circleci.com/gh/heroku/buildpacks-jvm/tree/main) +[![Registry](https://img.shields.io/badge/dynamic/json?url=https://registry.buildpacks.io/api/v1/buildpacks/heroku/maven&label=version&query=$.latest.version&color=DF0A6B&logo=&labelColor=white)](https://registry.buildpacks.io/buildpacks/heroku/maven) + +Heroku's official Cloud Native Buildpack for [Apache Maven](https://maven.apache.org/). + +This buildpack is designed to work in conjunction with other Heroku buildpacks and cannot be used independently. If you +want to build a Java application, use the `heroku/java` buildpack ([Source](/meta-buildpacks/java), +[Readme](/meta-buildpacks/java/README.md)) which includes this Maven buildpack. + +## How it works +### Step 1: Download Maven +If the application does not contain Maven Wrapper, the buildpack will download Maven and install it in its own layer. + +Users can specify the Maven version for their application by adding (or extending) a +[Java properties file](https://en.wikipedia.org/wiki/.properties) called `system.properties` in the root directory of +the application. + +The `maven.version` key determines the Maven version that is installed. Currently, supported versions are `3.2.5`, +`3.3.9`, `3.5.3`, and `3.6.2`. The default is `3.6.2`. + +### Step 2: Resolve settings.xml +A Maven `settings.xml` file defines values that configure Maven execution in various ways. Most commonly, it is used to +define a local repository location, alternate remote repository servers, and authentication information for private +repositories. + +When a file named `settings.xml` is present in the root directory of the application, the buildpack will automatically +use it to configure Maven at build time. The environment variable [MAVEN\_SETTINGS\_PATH](#MAVEN_SETTINGS_PATH) can be +used customize the file location. + +In addition, the [MAVEN\_SETTINGS\_URL](#MAVEN_SETTINGS_URL) environment variable can be used to instruct the buildpack +to download a `settings.xml` file from a remote host via HTTPS. + +### Step 3: Run Maven build +By default, the Maven command used to build the application is `mvn clean install -DskipTests`. Users can customize +this with the [MAVEN\_CUSTOM\_GOALS](#MAVEN_CUSTOM_GOALS) and [MAVEN\_CUSTOM\_OPTS](#MAVEN_CUSTOM_OPTS) environment +variables. + +In addition, some extra configuration is used to ensure Maven stores the local repository in a dedicated layer. + +### Step 4: Generate target/mvn-dependency-list.log +This buildpack will create a `target/mvn-dependency-list.log` in the application directory that can be used to later +determine which dependencies (including transitive ones) have been installed during build. + +### Step 5: launch.toml +For applications that use Spring Boot or Wildfly Swarm, this buildpack will generate a `launch.toml` with a process +type to launch the application. + + +## Reference +### Detect +Requires either `pom.xml`, `pom.atom`, `pom.clj`, `pom.groovy`, `pom.rb`, `pom.scala`, `pom.yaml`, or `pom.yml` at the +root of the application source. + +### Build Plan +#### Requires +##### `jdk` +To compile Java sources a JDK is required. It can be provided by the `heroku/jvm` ([Source](/buildpacks/jvm), +[Readme](/buildpacks/jvm/README.md)) buildpack. + +##### `jvm-application` +This is not a strict requirement of the buildpack. Requiring `jvm-application` ensures that this Maven buildpack can be +used even when no other buildpack requires `jvm-application.` + +#### Provides +##### `jvm-application` +Allows other buildpacks to depend on a compiled JVM application. + +### Environment Variables +#### `MAVEN_SETTINGS_PATH` +If you do not want the `settings.xml` file in the root directory or if you intend to frequently change between different +setting configurations, you may prefer to put a settings file in a custom location. The buildpack provides this +capability with the `MAVEN_SETTINGS_PATH` environment variable. +#### `MAVEN_SETTINGS_URL` +When the `MAVEN_SETTINGS_URL` config variable is defined, the buildpack will download the file at the given location +and use it to configure Maven. +#### `MAVEN_CUSTOM_OPTS` +Allows overriding Maven options used during the build process. The default options are `-DskipTests`. +#### `MAVEN_CUSTOM_GOALS` +Allows overriding the Maven goals used during the build process. The default goals are `clean install`. +#### `MAVEN_JAVA_OPTS` +Allows overriding the Java options for the Maven process during build. The default Java options are `-Xmx1024m`. +#### `HEROKU_BUILDPACK_DEBUG` +If set, the buildpack will emit debug log messages. ## License Licensed under the MIT License. See [LICENSE](../../LICENSE) file. From 0056a3ef60ef6709db3d8540ea5ce72d42289271 Mon Sep 17 00:00:00 2001 From: Manuel Fuchs Date: Mon, 15 Mar 2021 12:40:46 +0100 Subject: [PATCH 2/3] Update buildpacks/maven/README.md Co-authored-by: Ed Morley <501702+edmorley@users.noreply.github.com> --- buildpacks/maven/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/buildpacks/maven/README.md b/buildpacks/maven/README.md index 052b188f..6066d815 100644 --- a/buildpacks/maven/README.md +++ b/buildpacks/maven/README.md @@ -40,7 +40,7 @@ In addition, some extra configuration is used to ensure Maven stores the local r ### Step 4: Generate target/mvn-dependency-list.log This buildpack will create a `target/mvn-dependency-list.log` in the application directory that can be used to later -determine which dependencies (including transitive ones) have been installed during build. +determine which dependencies (including transitive ones) have been installed during the build. ### Step 5: launch.toml For applications that use Spring Boot or Wildfly Swarm, this buildpack will generate a `launch.toml` with a process From 30fa5bc4c36fdc5bb8823fadb77160c49f5efe3e Mon Sep 17 00:00:00 2001 From: Manuel Fuchs Date: Mon, 15 Mar 2021 12:40:52 +0100 Subject: [PATCH 3/3] Update buildpacks/maven/README.md Co-authored-by: Ed Morley <501702+edmorley@users.noreply.github.com> --- buildpacks/maven/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/buildpacks/maven/README.md b/buildpacks/maven/README.md index 6066d815..4c0f8363 100644 --- a/buildpacks/maven/README.md +++ b/buildpacks/maven/README.md @@ -43,7 +43,7 @@ This buildpack will create a `target/mvn-dependency-list.log` in the application determine which dependencies (including transitive ones) have been installed during the build. ### Step 5: launch.toml -For applications that use Spring Boot or Wildfly Swarm, this buildpack will generate a `launch.toml` with a process +For applications that use Spring Boot or Wildfly Swarm, this buildpack will generate a `launch.toml` with a `web` process type to launch the application.