Ease Maven Plugin
This plugin lets you release Maven artifacts in a very controlled way.
It doesn’t replace
deploy but modifies the project before these targets are executed.
The plugin works by adding simple metadata to artifacts during the release build, and then reading that data when deploying. Which means release build and deploy are fully separated. No building or dependency resolution happens during release, it’s just deploying existing artifacts from a known filesytem location.
aggregategoals are used while building a release.
attachgoal is used when deploying a release.
attachsignaturesgoal is used when deploying with gpg signatures included.
freeze goal should be added to all projects included in the release.
aggregate goal is used in a separate project.
This project should have everything that should go into the release as dependencies.
aggregate goal attaches the resulting list to the project just like the
freeze goal, it can be composed in multiple levels.
attachsignatures goals are used in a separate project.
This project should only be concerned with where to find the artifact list and the artifacts, and how to deploy the artifacts.
Add the plugin executions to the 'pom.xml' files.
Then just use normal
deploy goals to bring it to action.
freeze: Lists the artifacts (like the default jar, the sources jar etc.) atttached to a project and attaches the list to the project, as a -artifacts.txt artifact.
aggregate: Traverses the dependencies of a project and aggragates artifacts.txt files into one single list, which is then attached to the project. Note that any missing artifacts.txt file will fail the build — use includes/excludes filtering to target the dependencies you want.
attach: Attaches all artifacts in a given artifacts.txt file to the project. A file location for this file is used to prevent any dependency resolution whatsoever to take place. A separate local repo can be defined for loading the artifacts from, which is very much recommended.
attachsignatures: Attaches the signatures of all artifacts to the project. Missing signatures will fail the build.
Use the included test/example projects
mvn clean install -Dpreparewill install the plugin and freeze some artifacts and then aggregate them.
mvn clean install -Dperformwill attach the previously created artifacts to a project and install them (again). To deploy with gpg signatures, remove the
<phase>none</phase>setting from the attach example project.