Java 8+ is required for the tooling, plugins, etc. Maven 3.8+ is recommended.
As in the Java-SDK, we target Java 8. The parent POM configures this automatically.
- Create a standard directory structure in the appropriate folder (
hooks/
,providers/
). - Create a new
pom.xml
in the root of your new module. It must inherit from the parent POM, which implements the javadoc, testing, publishing, and other boilerplate. Be sure to add<!--x-release-please-version -->
on the line specifying the module version, so our release tooling can update it (see sample pom below). - Add the new package to
release-please-config.json
. - Add the new module to the
<modules>...</modules>
section in the parentpom.xml
. - Add a
version.txt
file with a version matching that in your newpom.xml
, e.g.0.0.1
. - If you care to release a pre 1.0.0 version, add the same version above to
.release-please-manifest.json
. Failing to do this will release a1.0.0
initial release.
Sample pom.xml:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>dev.openfeature.contrib</groupId>
<artifactId>parent</artifactId>
<version><!-- current parent pom version --></version>
<relativePath>../../pom.xml</relativePath>
</parent>
<!-- The group id MUST start with dev.openfeature, or publishing will fail. OpenFeature has verified ownership of this (reversed) domain. -->
<groupId>dev.openfeature.contrib.${providers | hooks | etc}</groupId>
<artifactId>module</artifactId>
<version>0.0.1</version> <!--x-release-please-version -->
<name>module</name>
<description>Your module description</description>
<url>https://openfeature.dev</url>
<developers>
<developer>
<id>Your GitHub ID</id>
<name>Your Name</name>
<organization>OpenFeature</organization>
<url>https://openfeature.dev/</url>
</developer>
</developers>
<dependencies>
<!-- dependencies your module needs (in addition to those inherited from parent) -->
</dependencies>
<build>
<plugins>
<!-- plugins your module needs (in addition to those inherited from parent) -->
</plugins>
</build>
</project>
Any published modules must have documentation in their root directory, explaining the basic purpose of the module as well as installation and usage instructions. Instructions for how to develop a module should also be included (required system dependencies, instructions for testing locally, etc).
Any published modules must have reasonable test coverage. The parent POM adds basic testing support for you.
Use mvn clean test
to test the entire project.
Use mvn --projects {MODULE PATH} clean test
to test just a single module.
Use mvn clean verify
to test/audit/lint the entire project.
Use mvn --projects {MODULE PATH} clean verify
to test/audit/lint just a single module.
As described in the README, this project uses release-please, and semantic versioning. Breaking changes should be identified by using a semantic PR title.
Keep dependencies to a minimum, especially compile
dependencies. Do not include dependencies specific to your module in the parent, add them to your module's POM.xml
.
The Java-SDK should be a provided dependency of your module, the parent POM takes care of this automatically.
Keep in mind, one version of the Java-SDK is used for all modules.
To use vscode, install the standard Java language support extension by Red Hat.
The following vscode settings are recommended (create a workspace settings file at .vscode/settings.json):
{
"java.configuration.updateBuildConfiguration": "interactive",
"java.autobuild.enabled": false,
"java.checkstyle.configuration": "${workspaceFolder}/checkstyle.xml",
"java.checkstyle.version": "10.3.2",
"java.format.settings.url": "${workspaceFolder}/eclipse-java-google-style.xml",
"java.format.enabled": false
}