Skip to content

Commit

Permalink
Merge pull request #63 from heroku/malax/maven-readme
Browse files Browse the repository at this point in the history
Add heroku/maven README
  • Loading branch information
Malax authored Mar 15, 2021
2 parents 7839257 + 30fa5bc commit 752fb19
Show file tree
Hide file tree
Showing 2 changed files with 85 additions and 1 deletion.
1 change: 1 addition & 0 deletions buildpacks/maven/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -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

Expand Down
85 changes: 84 additions & 1 deletion buildpacks/maven/README.md
Original file line number Diff line number Diff line change
@@ -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 the build.

### Step 5: launch.toml
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.


## 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.

0 comments on commit 752fb19

Please sign in to comment.