This repository provides a Java Maven project template for creating Java projects with built-in static analysis tools, code quality checks, dependency management, and CI/CD integration. It is designed to serve as a starting point for new Java projects, ensuring consistency and quality from the outset.
- Maven Project Structure: Configured for Java 21 with a standard project layout.
- Code Formatting: Uses Spotless with Palantir Java Format for consistent code style.
- Static Analysis: Integrates Error Prone and NullAway for catching bugs and enforcing null safety.
- Dependency Management: Employs the Maven Enforcer Plugin to enforce rules like banning duplicate dependencies and requiring Java 21.
- CI/CD: Includes a GitHub Actions workflow for automated builds and Dependabot for dependency updates.
- IDE Settings: Pre-configured code style settings for IntelliJ IDEA.
- Maven Wrapper: Ensures consistent builds across different environments with Maven 3.9.9 (wrapper version 3.3.2).
- Consistent Line Endings: Enforced via .gitattributesfor cross-platform compatibility.
To start a new project using this template, follow these steps:
- Clone the Repository:
git clone https://github.com/your-username/your-repo.git cd your-repo
- Update pom.xml:
- Modify the groupId,artifactId, andversionto match your project.
- Example:
<groupId>io.company</groupId> <artifactId>app</artifactId> <version>0.0.1-SNAPSHOT</version> 
 
- Modify the 
- Rename Package Structure (if necessary):
- Update the package names in the source files (e.g., src/main/java/io/company) to align with your project's structure.
 
- Update the package names in the source files (e.g., 
- Start Developing:
- Use the included Maven wrapper to build and run your project:
./mvnw clean verify 
- The Maven wrapper ensures you don’t need to install Maven locally, using version 3.9.9 as specified.
 
- Use the included Maven wrapper to build and run your project:
- Spotless Maven Plugin:
- Formats Java code using Palantir Java Format with the PALANTIR style.
- Features:
- Removes unused imports.
- Formats annotations and Javadoc.
- Trims trailing whitespace and ensures files end with a newline.
- Enforces a specific import order (#, java, org, com, <others>).
- Uses 4-space indentation and UNIX line endings (\n).
 
- Also formats YAML files in .github/(e.g.,dependabot.yml,build.yml) with 2-space indentation.
 
- Maven Enforcer Plugin:
- Enforces rules such as:
- Banning duplicate POM dependency versions and dynamic versions.
- Excluding vulnerable dependencies (e.g., Log4j versions < 2.17.0).
- Ensuring dependency convergence.
- Requiring Java 21.
 
- Fails the build if any rule is violated.
 
- Enforces rules such as:
- Maven Compiler Plugin:
- Compiles with Java 21.
- Integrates Error Prone and NullAway for static analysis.
- Error Prone:
- Detects common programming bugs during compilation.
- Configured to fail the build on warnings to ensure high-quality code.
 
- NullAway:
- Provides comprehensive nullness analysis during compilation.
- Prevents potential NullPointerExceptions by requiring proper null annotations.
 
 
- Error Prone:
- Configured to fail on warnings to maintain code quality.
- Uses JSpecify annotations for null safety within the io.companypackage.
 
- JSpecify:
- Provides annotations for null safety, used in conjunction with NullAway.
 
- Import Order: Groups imports as: static imports,java,org,com, andothers, with blank lines between groups.
- Indentation: Uses 4 spaces for Java code, 2 spaces for YAML.
- Line Endings: Ensures UNIX-style line endings (\n) for all files.
- Spotless formats YAML files in the .github/directory, ensuring consistent 2-space indentation and UNIX line endings.
- Workflow File: .github/workflows/build.yml
- Triggers:
- Pushes to the mainbranch.
- Pull requests.
 
- Pushes to the 
- Jobs:
- Runs on ubuntu-latestwith Java 21 (Temurin distribution).
- Steps:
- Maximizes disk space for the build environment.
- Sets up Java 21.
- Checks out the code.
- Grants execution permissions to the Maven wrapper.
- Builds the project with ./mvnw clean verify -T 2.0C --batch-mode.
- Extracts the artifactIdandversionfrom the POM.
- Uploads the resulting .jarfile as an artifact (e.g.,app-0.0.1-SNAPSHOT.jar).
 
 
- Runs on 
- Configuration File: .github/dependabot.yml
- Updates:
- Checks daily for updates to:
- Maven dependencies (in /).
- GitHub Actions configurations (in /).
 
- Maven dependencies (in 
 
- Checks daily for updates to:
The template includes IntelliJ IDEA settings for consistent code style:
- External Dependencies:
- Configured to use Palantir Java Format (see .idea/externalDependencies.xml).
 
- Configured to use Palantir Java Format (see 
- Code Style:
- Import layout matches the Spotless configuration (see .idea/codeStyles/Project.xml).
- Applied automatically when opening the project in IntelliJ IDEA.
 
- Import layout matches the Spotless configuration (see 
These settings are stored in the .idea/ directory.
The following build configurations are pre-set and can be used in your IDE:
- [Clean] With tests:
clean verify -T 1.0C 
- [Clean] Without tests:
clean verify -T 1.0C -Dmaven.test.skip=true 
- [Incremental] With tests:
verify -T 1.0C 
- [Incremental] Without tests:
verify -T 1.0C -Dmaven.test.skip=true 
- [Spotless] Fix code style:
spotless:apply 
These commands use -T 1.0C for parallel builds with one thread per CPU core.
- .gitattributes:
- Ensures all text files use UNIX-style line endings (\n) with* text eol=lf, promoting cross-platform consistency.
 
- Ensures all text files use UNIX-style line endings (
Contributions are welcome! Feel free to open issues or submit pull requests to improve this template or add more features.