From 99476f7d8231d0c78c43057767397f1ff5964ea9 Mon Sep 17 00:00:00 2001 From: Alexander Kriegisch Date: Wed, 5 May 2021 16:21:53 +0700 Subject: Provision libraries in 'lib' automatically Upon special request by Andy Clement, I included 'lib' as a child module in the parent POM again, making several modules which refer to downloaded library files dependent the 'lib' module. I am not sure I caught all of them, but I hope so. Now after cloning the project and configuring the token for reading from GitHub Packages (sorry!), you can just run a Maven build for the main project and no longer need to fail the first build, read the Maven Enforcer message and run 'cd lib && mvn compile' as a first step. This convenience comes at the price of a more complex POM and two new profiles: - Profile 'provision-libs' is auto-activated by the absence of a marker file, kicking off the library provisioning process and creating same marker file at the end, if successful. Therefore, during subsequent builds libraries will not be re-provisioned, because the marker file exists and Maven skips all download and (un)zip steps, which saves build time and bandwidth. Otherwise offline builds would not work either. - Profile 'clean-libs' needs to be activated manually, because by default 'mvn clean' will not erase provisioned libraries. In most cases, even after a clean a developer does not want to re-provision all libraries if they have not changed (e.g. new JDT Core build). But if you do wish too erase the libraries and the marker file, just call 'cd lib && mvn -P clean-libs clean'. Please note: The Maven Enforcer build step, which additionally checks for existence of other files, still exists and was moved from the parent POM to 'libs'. No matter if provisioning was just done or skipped because the main marker file exists, a quick heuristic check for that list of files is done during each build, failing the build with a comprehensive message if an inconsistency was found. The error message says which files are missing and tells the user: "There is an inconsistency in module subdirectory 'lib'. Please run 'mvn --projects lib -P clean-libs clean compile'. This should take care of cleaning and freshly downloading all necessary libraries to that directory, where some tests expect them to be." This should cover the topic. Signed-off-by: Alexander Kriegisch --- pom.xml | 51 ++++++++------------------------------------------- 1 file changed, 8 insertions(+), 43 deletions(-) (limited to 'pom.xml') diff --git a/pom.xml b/pom.xml index 8f5a31b2a..a6da6f707 100644 --- a/pom.xml +++ b/pom.xml @@ -27,7 +27,6 @@ 1.0.1 LOGGING_1_0_1 9.1 - ${maven.multiModuleProjectDirectory}/lib @@ -47,6 +46,7 @@ + lib util bridge testing-util @@ -73,7 +73,6 @@ @@ -279,51 +278,11 @@ junit:junit:jar + org.aspectj:lib:jar - - org.apache.maven.plugins - maven-enforcer-plugin - - - enforce-libraries-exist - - enforce - - - - - - - Please go to module subdirectory 'lib' and run 'mvn compile' there. This should take care of downloading all necessary libraries to that directory, where some tests expect them to be. - - - ${lib.directory}/ant/bin/ant.bat - ${lib.directory}/ant/lib/junit.jar - ${lib.directory}/commons/commons.jar - ${lib.directory}/docbook/docbook-dtd/docbookx.dtd - ${lib.directory}/docbook/docbook-xsl/html/chunk.xsl - ${lib.directory}/docbook/fop.jar - ${lib.directory}/docbook/batik.jar - ${lib.directory}/jarjar/jarjar-1.3.jar - ${lib.directory}/jdtcore-aj/jdtcore-for-aspectj.jar - ${lib.directory}/junit/junit.jar - ${lib.directory}/regexp/jakarta-regexp-1.2.jar - ${lib.directory}/saxon/saxon.jar - - - - true - - - - - @@ -364,6 +323,12 @@ asm-renamed ${asm.version} + + + org.aspectj + lib + ${project.version} + -- cgit v1.2.3