summaryrefslogtreecommitdiffstats
path: root/pom.xml
diff options
context:
space:
mode:
authordfarrelly <david.farrelly@est.tech>2019-07-24 16:17:13 +0000
committerdfarrelly <david.farrelly@est.tech>2019-07-24 16:17:13 +0000
commit924a805b71005f56fed260e1b92e4e27ef0a381f (patch)
treeebfa129f17b3b5d8cfb6091b9e18fa478d325aa1 /pom.xml
parent2c8ddf3501cfc5106d20b51ef077cc6d07ab65dc (diff)
Align PM Mapper to new build guidelines
*Switch to Fabric8 docker maven plugin *Add git commit plugin *Remove shaded jar *Remove some unused imports *Add a human readable log file Issue-ID: DCAEGEN2-1683 Change-Id: I1028f3195d3f03a9d919c91073398b01ccd6d7d1 Signed-off-by: dfarrelly <david.farrelly@est.tech>
Diffstat (limited to 'pom.xml')
-rw-r--r--pom.xml168
1 files changed, 109 insertions, 59 deletions
diff --git a/pom.xml b/pom.xml
index 2b2b1e1..41a8d73 100644
--- a/pom.xml
+++ b/pom.xml
@@ -26,7 +26,7 @@
<groupId>org.onap.dcaegen2.services</groupId>
<artifactId>pm-mapper</artifactId>
- <version>1.1.2-SNAPSHOT</version>
+ <version>1.1.3-SNAPSHOT</version>
<parent>
<groupId>org.onap.oparent</groupId>
@@ -59,10 +59,13 @@
<xerces.version>2.11.0</xerces.version>
<reactor.test>3.1.0.RELEASE</reactor.test>
<!-- Plugin Versions -->
- <shade.plugin.version>3.2.0</shade.plugin.version>
<jacoco.version>0.8.2</jacoco.version>
- <dockerfile.version>1.4.10</dockerfile.version>
<surefire.version>2.22.0</surefire.version>
+ <git-commit.version>3.0.0</git-commit.version>
+ <build-helper.version>3.0.0</build-helper.version>
+ <docker-maven.version>0.30.0</docker-maven.version>
+ <maven-jar.version>3.1.2</maven-jar.version>
+ <dependencies.version>3.1.1</dependencies.version>
<!-- Plugin Settings -->
<image-name>${docker.push.registry}/onap/${project.groupId}.${project.artifactId}</image-name>
<maven.build.timestamp.format>yyyyMMdd'T'HHmmss'Z'</maven.build.timestamp.format>
@@ -75,9 +78,11 @@
<sonar.projectVersion>${project.version}</sonar.projectVersion>
<compiler.target.version>1.8</compiler.target.version>
<compiler.source.version>1.8</compiler.source.version>
- <shade.main>org.onap.dcaegen2.services.pmmapper.App</shade.main>
- <shade.transformer>org.apache.maven.plugins.shade.resource.ManifestResourceTransformer</shade.transformer>
<onap.logging.version>1.2.2</onap.logging.version>
+ <classpath.separator>@@</classpath.separator>
+ <pmmapper.main.class>org.onap.dcaegen2.services.pmmapper.App</pmmapper.main.class>
+ <dep.dir.name>libs</dep.dir.name>
+ <ext.dep.dir.path>${dep.dir.name}/external</ext.dep.dir.path>
</properties>
<dependencies>
@@ -211,60 +216,127 @@
<build>
<plugins>
<plugin>
- <groupId>com.spotify</groupId>
- <artifactId>dockerfile-maven-plugin</artifactId>
- <version>${dockerfile.version}</version>
+ <groupId>pl.project13.maven</groupId>
+ <artifactId>git-commit-id-plugin</artifactId>
+ <version>${git-commit.version}</version>
<configuration>
- <repository>${image-name}</repository>
- <dockerfile>${project.build.outputDirectory}/Dockerfile</dockerfile>
- <buildArgs>
- <JAR>${project.build.finalName}-jar-with-dependencies.jar</JAR>
- </buildArgs>
+ <dateFormat>${maven.build.timestamp.format}</dateFormat>
</configuration>
<executions>
<execution>
- <id>tag-version</id>
- <phase>none</phase>
+ <id>get-git-info</id>
<goals>
- <goal>tag</goal>
+ <goal>revision</goal>
</goals>
- <configuration>
- <tag>${project.version}-${timestamp}</tag>
- </configuration>
- </execution>
- <execution>
- <id>latest-snapshot</id>
- <phase>none</phase>
- <goals>
- <goal>tag</goal>
- </goals>
- <configuration>
- <tag>latest-snapshot</tag>
- </configuration>
</execution>
+ </executions>
+ </plugin>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-dependency-plugin</artifactId>
+ <version>${dependencies.version}</version>
+ <configuration>
+ <silent>true</silent>
+ <includeScope>runtime</includeScope>
+ <pathSeparator>${classpath.separator}</pathSeparator>
+ </configuration>
+ <executions>
<execution>
- <id>push-latest</id>
- <phase>none</phase>
+ <id>copy-external-dependencies</id>
+ <phase>prepare-package</phase>
<goals>
- <goal>push</goal>
+ <goal>copy-dependencies</goal>
+ <goal>build-classpath</goal>
</goals>
<configuration>
- <tag>latest-snapshot</tag>
+ <excludeGroupIds>${project.parent.groupId}</excludeGroupIds>
+ <outputDirectory>${project.build.directory}/${ext.dep.dir.path}</outputDirectory>
+ <prefix>./${ext.dep.dir.path}</prefix>
+ <outputProperty>classpath.external</outputProperty>
</configuration>
</execution>
+ </executions>
+ </plugin>
+ <plugin>
+ <groupId>org.codehaus.mojo</groupId>
+ <artifactId>build-helper-maven-plugin</artifactId>
+ <version>${build-helper.version}</version>
+ <executions>
<execution>
- <id>push-version</id>
- <phase>none</phase>
+ <id>fix-classpath-separator</id>
+ <phase>prepare-package</phase>
<goals>
- <goal>push</goal>
+ <goal>regex-properties</goal>
</goals>
<configuration>
- <tag>${project.version}-${timestamp}</tag>
+ <regexPropertySettings>
+ <regexPropertySetting>
+ <name>classpath.external</name>
+ <value>${classpath.external}</value>
+ <regex>${classpath.separator}</regex>
+ <replacement xml:space="preserve"> </replacement>
+ </regexPropertySetting>
+ </regexPropertySettings>
</configuration>
</execution>
</executions>
</plugin>
<plugin>
+ <groupId>io.fabric8</groupId>
+ <artifactId>docker-maven-plugin</artifactId>
+ <version>${docker-maven.version}</version>
+ <configuration>
+ <images>
+ <image>
+ <name>${project.groupId}.${project.artifactId}</name>
+ <registry>${onap.nexus.dockerregistry.daily}</registry>
+ <build>
+ <contextDir>${project.basedir}</contextDir>
+ <dockerFile>${project.build.outputDirectory}/Dockerfile</dockerFile>
+ <args>
+ <JAR>${project.build.finalName}.jar</JAR>
+ </args>
+ <cleanup>none</cleanup>
+ <tags>
+ <tag>${project.version}</tag>
+ <tag>${project.version}-${maven.build.timestamp}Z</tag>
+ </tags>
+ </build>
+ </image>
+ </images>
+ </configuration>
+ </plugin>
+ <plugin>
+ <groupId>org.apache.maven.plugins</groupId>
+ <artifactId>maven-jar-plugin</artifactId>
+ <version>${maven-jar.version}</version>
+ <configuration>
+ <archive>
+ <manifest>
+ <mainClass>${pmmapper.main.class}</mainClass>
+ <addDefaultImplementationEntries>true</addDefaultImplementationEntries>
+ <addBuildEnvironmentEntries>true</addBuildEnvironmentEntries>
+ <useUniqueVersions>false</useUniqueVersions> <!-- workaround for MJAR-156 -->
+ </manifest>
+ <manifestEntries>
+ <Class-Path>${classpath.external}</Class-Path>
+ <Git-Branch>${git.branch}</Git-Branch>
+ <Git-Build-Host>${git.build.host}</Git-Build-Host>
+ <Git-Build-Time>${git.build.time}</Git-Build-Time>
+ <Git-Build-User-Email>${git.build.user.email}</Git-Build-User-Email>
+ <Git-Build-User-Name>${git.build.user.name}</Git-Build-User-Name>
+ <Git-Build-Version>${git.build.version}</Git-Build-Version>
+ <Git-Closest-Tag-Name>${git.closest.tag.name}</Git-Closest-Tag-Name>
+ <Git-Commit-Id>${git.commit.id}</Git-Commit-Id>
+ <Git-Commit-Message-Short>${git.commit.message.short}</Git-Commit-Message-Short>
+ <Git-Commit-Time>${git.commit.time}</Git-Commit-Time>
+ <Git-Commit-User-Email>${git.commit.user.email}</Git-Commit-User-Email>
+ <Git-Commit-User-Name>${git.commit.user.name}</Git-Commit-User-Name>
+ </manifestEntries>
+ </archive>
+ </configuration>
+ </plugin>
+ <plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-surefire-plugin</artifactId>
<version>${surefire.version}</version>
@@ -279,28 +351,6 @@
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
- <artifactId>maven-shade-plugin</artifactId>
- <version>${shade.plugin.version}</version>
- <executions>
- <execution>
- <goals>
- <goal>shade</goal>
- </goals>
- <configuration>
- <shadedArtifactAttached>true</shadedArtifactAttached>
- <shadedClassifierName>jar-with-dependencies</shadedClassifierName>
- <transformers>
- <transformer
- implementation="${shade.transformer}">
- <mainClass>${shade.main}</mainClass>
- </transformer>
- </transformers>
- </configuration>
- </execution>
- </executions>
- </plugin>
- <plugin>
- <groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>${maven.compiler.source}</source>