Closes #38888 Signed-off-by: Ryan Emerson <remerson@ibm.com> Signed-off-by: Alexander Schwartz <alexander.schwartz@ibm.com> Signed-off-by: Pedro Ruivo <1492066+pruivo@users.noreply.github.com> Co-authored-by: Pedro Ruivo <pruivo@users.noreply.github.com> Co-authored-by: Alexander Schwartz <alexander.schwartz@ibm.com> |
||
|---|---|---|
| .. | ||
| src | ||
| pom.xml | ||
| README.md | ||
Database Compatibility Verifier Maven Plugin
Overview
This Maven plugin is used to verify the database compatibility of Keycloak. It ensures that all database schema changes (ChangeSets) are explicitly marked as either supported or unsupported by the rolling upgrades feature.
Goals
The plugin provides the following goals:
db-compatibility-verifier:snapshotdb-compatibility-verifier:verifydb-compatibility-verifier:supporteddb-compatibility-verifier:unsupported
Usage
snapshot - Creates a snapshot of the current database ChangeSets.
This goal is used to create an initial snapshot of the database ChangeSets. It creates a supported and unsupported JSON
file, specified via the db.verify.supportedFile and db.verify.unsupportedFile property, respectively.
mvn org.keycloak:db-compatibility-verifier-maven-plugin:999.0.0-SNAPSHOT:snapshot \
-Ddb.verify.supportedFile=<relative-path-to-create-json-file> \
-Ddb.verify.unsupportedFile=<relative-path-to-create-json-file>
The supportedFile will be created with a record of all known ChangeSets and the unsupportedFile will be initialized
as an empty JSON array.
verify - Verifies that all detected ChangeSets recorded in either the supported or unsupported JSON files.
mvn org.keycloak:db-compatibility-verifier-maven-plugin:999.0.0-SNAPSHOT:verify \
-Ddb.verify.supportedFile=<relative-path-to-json-file> \
-Ddb.verify.unsupportedFile=<relative-path-to-json-file>
supported - Adds one or all missing ChangeSets to the supported JSON file
This goal is used to mark a ChangeSet as supported for rolling upgrades.
To mark a single ChangeSet as supported:
mvn org.keycloak:db-compatibility-verifier-maven-plugin:999.0.0-SNAPSHOT:supported \
-Ddb.verify.supportedFile=<relative-path-to-json-file> \
-Ddb.verify.unsupportedFile=<relative-path-to-json-file> \
-Ddb.verify.changset.id=<id> \
-Ddb.verify.changset.author=<author> \
-Ddb.verify.changset.filename=<filename>
To mark all missing ChangeSets as supported:
mvn org.keycloak:db-compatibility-verifier-maven-plugin:999.0.0-SNAPSHOT:supported \
-Ddb.verify.supportedFile=<relative-path-to-json-file> \
-Ddb.verify.unsupportedFile=<relative-path-to-json-file> \
-Ddb.verify.changset.addAll=true
unsupported - Adds one or all missing ChangeSets to the unsupported JSON file
This goal is used to mark a ChangeSet as unsupported for rolling upgrades.
To mark a single ChangeSet as unsupported:
mvn org.keycloak:db-compatibility-verifier-maven-plugin:999.0.0-SNAPSHOT:unsupported \
-Ddb.verify.supportedFile=<relative-path-to-json-file> \
-Ddb.verify.unsupportedFile=<relative-path-to-json-file> \
-Ddb.verify.changset.id=<id> \
-Ddb.verify.changset.author=<author> \
-Ddb.verify.changset.filename=<filename>
To mark all missing ChangeSets as unsupported:
mvn org.keycloak:db-compatibility-verifier-maven-plugin:999.0.0-SNAPSHOT:unsupported \
-Ddb.verify.supportedFile=<relative-path-to-json-file> \
-Ddb.verify.unsupportedFile=<relative-path-to-json-file> \
-Ddb.verify.changset.addAll=true