Apache Maven Enforcer Plugin Example
1. Apache Maven Enforcer Plugin – Introduction
Maven is a software project management and comprehension tool. Based on the concept of a project object model (POM), Maven can manage a project’s build, reporting and documentation from a central piece of information.
1.1 Maven installation guide
You just need to download the Maven’s zip file, unzip it to a folder, and configure the Windows environment variables.
1.2 JDK and JAVA_HOME
Make sure JDK is installed, and JAVA_HOME
environment variable is configured. Follow the steps below to see Environment Variables:
- Right click the Computer icon.
- Choose Properties from the context menu.
- Click the Advanced system settings link.
- Click Environment Variables.
data:image/s3,"s3://crabby-images/ef25a/ef25a5d83af0be39a0945a32efee119a4cfdb526" alt="Apache Maven Enforcer - Configure JAVA_HOME"
1.3 Download Apache Maven
Visit Maven official website, download the Maven zip file, for example apache-maven-3.6.1-bin.zip
. Unzip it to a folder: C:\Program Files\apache-maven-3.6.1
data:image/s3,"s3://crabby-images/7bbaf/7bbafa7c3e5f24e6d4623a20e0297375f3e3182d" alt="Apache Maven Enforcer - apache-maven-3.6.1"
That’s all, just download and unzip, installation is NOT required.
1.4 Add MAVEN_HOME system variable
Add a MAVEN_HOME
system variables, and point it to the Maven folder.
Here are the steps to add a new variable:
data:image/s3,"s3://crabby-images/7ba27/7ba27f589ed6c7287beaeaaa6b95803f135233fd" alt="Apache Maven Enforcer - System Properties"
Click New to add a new variable:
data:image/s3,"s3://crabby-images/fb852/fb852e9ca0ccdd205120da55a07f09b23bbe634c" alt=""
Pay attention to the capital letters of the variable name, as it is case sensitive.
Variable value points to the location we extracted the Maven zip file.
data:image/s3,"s3://crabby-images/79e5b/79e5b98fb32bf72761f5337c33048a9539bb2471" alt="Apache Maven Enforcer - Define variable name"
1.5 Add %MAVEN_HOME%\bin To PATH
In system variables, find PATH
variable and follow the steps below:
Click Edit:
data:image/s3,"s3://crabby-images/3adbd/3adbd68865afcd319ce70029c6b569d146a2e270" alt="Apache Maven Enforcer - click on Edit button"
Add %MAVEN_HOME%\bin to the end of the Variable value:
data:image/s3,"s3://crabby-images/83853/8385314486804a286e80f5971070486432290c07" alt="Apache Maven Enforcer - %MAVEN_HOME%\bin"
1.6 Verification
Done, start a new command prompt, type mvn –version
: Holddown the Windows Key and Press R on your keyboard.
data:image/s3,"s3://crabby-images/c9b66/c9b66409c297dc3e702524250bae206c5dddf131" alt="Apache Maven Enforcer - Command Prompt"
By clicking OK, cmd.exe runs. Now type the command below:
data:image/s3,"s3://crabby-images/74ae8/74ae8168f0d88bf5833208766981406d22ea8f76" alt="Apache Maven Enforcer - Maven installation"
2. What is Maven Enforcer Plugin?
The Enforcer plugin helps maintain project standards and provides goals to control certain environmental constraints such as Maven version, JDK version and OS family along with many more standard(built-in) rules and user created rules.
General instructions on how to use the Enforcer Plugin can be found on the usage page.
3. What can the Enforcer plugin do for the project?
Generally we can use it to guarantee the level of compliance in our project, it is especially handy when we have distributed teams:
- Enforce banned dependencies:
- Dependencies that are undesirable by your organization can be banned and reported during the build so that other developers can not add them to the pom.
- Some third party dependencies include transitive dependencies that may conflict with your project’s dependencies. For example: If your project uses Logback and SFL4j, it is a best practice to ensure no other logging frameworks are included in the build.
- Reduce package size when packaging the application in a war or jar, by excluding banned dependencies.
- Enforce a specific version of Java, OS, and Maven.
Now lets see how to use this plugin using an example:
4. Plugin Configuration and Goals
Maven Enforcer has two goals:
- enforcer:enforce goal: runs during a project build to execute rules specified in the configuration
- enforcer:display-info goal: shows current information about the built-in rules that are present in the project’s pom.xml
5. Create a Maven project
Open IntelliJ Idea, choose Create New Project:
data:image/s3,"s3://crabby-images/1b4dd/1b4dd3981306fcf435a0f73ad27a5b1cadf85b03" alt="Apache Maven Enforcer - New Project"
From the right sidebar select Maven:
data:image/s3,"s3://crabby-images/c5f7c/c5f7c6cfb1b6cb04937dcd31ccb9dda2cb81df19" alt="Apache Maven Enforcer - Select Maven"
In the next window enter GroupId and ArtifactId as you wish:
data:image/s3,"s3://crabby-images/d5ac9/d5ac9548af8a62beb124c99a2bd2692da2e8a4d2" alt="Apache Maven Enforcer - Fill the GroupId, ArtifactId"
By clicking Next the Project name and location is displayed. You can change the values as you wish.
data:image/s3,"s3://crabby-images/cdb0b/cdb0bbb0e2daaa3e86b147686511507d39aa2c45" alt="Apache Maven Enforcer - Final-step"
After clicking the “Finish” button this window appears in the IDE:
data:image/s3,"s3://crabby-images/5c214/5c2143804546d334033d5d3e9714b3777a13c004" alt="Apache Maven Enforcer - Main window"
Let’s define the enforce goal in the executions tag. Furthermore, we’ll add the configuration tag that holds the rules definitions for the project:
executions tag:
... <executions> <execution> <id>enforce</id> <goals> <goal>enforce</goal> </goals> <configuration> <rules> <requireMavenVersion> <version>4.0</version> <message>Invalid Maven version. It should, at least, be 4.0</message> </requireMavenVersion> <requireJavaVersion> <version>1.9</version> <message>Invalid Java version. It should, at least, be 1.9</message> </requireJavaVersion> </rules> </configuration> </execution> </executions> ...
The keyword enforce shows there are rules to follow. In fact the rules are enforced during the build phase of the project.
The available built-in rules are described here. Each rule to be executed should be added to the rules element along with the specific configuration for that rule.
- requireMavenVersion rule enforces certain Maven versions.
- requireJavaVersion rule enforces certain Java JDK versions.
- requireOs rule can enforce certain values about the Operating System and processor architecture.
All rules also accept a message parameter for specifying a custom message:
rules:
... <requireMavenVersion> <version>4.0</version> <message>Invalid Maven version. It should, at least, be 4.0</message> </requireMavenVersion> ...
To check the rule’s behavior, we run mvn clean compile
in the Terminal window:
data:image/s3,"s3://crabby-images/5d349/5d349c7112458f9633c7b8d4a7ae6ba3a5ae79ee" alt="Apache Maven Enforcer - Compile command"
It’ll produce the following error lines on the console:
data:image/s3,"s3://crabby-images/a7152/a7152034210ed68fa2b1c1fdca5f5f3295cd6f56" alt="Apache Maven Enforcer - Compile result"
As you see we have warnings on Rule 1 and Rule 2 with our defined messages.
Now we add another rule related to OS version:
Require OS Version: This rule can enforce certain values about the Operating System and processor architecture. The values and code used to determine if an OS is allowed are exactly the same as the OS Profile activation in Maven.
rules:
... <requireOS> <family>unix</family> </requireOS>
To check the rule’s behavior, we run again mvn clean compile
in the Terminal window. We can run first mvn clean
then mvn compile
data:image/s3,"s3://crabby-images/3a44a/3a44a0da782f0f190f5ccf7720e329044afb540c" alt="Apache Maven Enforcer - mvn clean"
Now we run the install command:
data:image/s3,"s3://crabby-images/63c69/63c69084c936bf2a9ebfb496dd8956f95d88e1c9" alt="Apache Maven Enforcer - mvn install"
As you see there is one rule added to WARNINGs saying that windows 7 is not allowed.
6. Download the Complete Source Code
This was a tutorial of Apache Maven Enforcer Plugin Example.
You can download the full source code of this example here: Apache Maven Enforcer Plugin Example