Full name:
org.revapi:revapi-maven-plugin:0.14.4:convert-config-to-xml
Description:
Note that this does not touch the external configuration files. The old and new style configuration still works together well, though.
Note that this goal changes the contents of pom.xml of the built modules. You are advised to check the modifications for correctness and to update the formatting of the changed lines to your liking.
Attributes:
0.9.0.validate.| Name | Type | Since | Description | 
|---|---|---|---|
| <alwaysCheckForReleaseVersion> | boolean | 0.9.0 | If true (the default) revapi will always download the information
about the latest version from the remote repositories (instead of
using locally cached info). This will respect the offline settings. Default value is: true.User property is: revapi.alwaysCheckForReleaseVersion. | 
| <analysisConfiguration> | PlexusConfiguration | 0.9.0 | The JSON or XML configuration of various analysis options. The
available options depend on what analyzers are present on the
plugin classpath through the <dependencies>.
Consult configuration
documentation for more details.These settings take precedence over the configuration loaded
from  | 
| <analysisConfigurationFiles> | Object[] | 0.9.0 | The list of files containing the configuration of various analysis
options. The available options depend on what analyzers are present
on the plugins classpath through the <dependencies>.The  The list is either a list of strings or has the following form: 
 pathorresourcehas to be
specified but not both. Theconfiguration/root1andconfiguration/root2are paths to the roots of the
configuration inside that JSON/XML config file. This might be used
in cases where multiple configurations are stored within a single
file and you want to use a particular one.An example of this might be a config file which contains API changes to be ignored in all past versions of a library. The classes to be ignored are specified in a configuration that is specific for each version: 
User property is: revapi.analysisConfigurationFiles. | 
| <checkDependencies> | boolean | 0.9.0 | Whether to include the dependencies in the API checks. This is the
default thing to do because your API might be exposing classes from
the dependencies and thus classes from your dependencies could
become part of your API. However, setting this to false might be useful in situations where you have checked your dependencies in another module and don't want do that again. In that case, you might want to configure Revapi to ignore missing classes because it might find the classes from your dependencies as used in your API and would complain that it could not find it. See the docs. Default value is: true.User property is: revapi.checkDependencies. | 
| <convertAnalysisConfigurationFiles> | boolean | 0.9.0 | Whether to convert the contents of the external configuration files
specified by the analysisConfigurationFilesfrom JSON
to XML.Note that external configuration files with custom root elements are not supported, because it would not be clear how to convert the rest of the file into XML. Also note that the original file will be left intact by the conversion and a new file with the same name and ".xml" extension will be created in the same directory and the pom.xml will be updated to point to this new file. You should delete the old file after making sure the conversion went fine. Default value is: false.User property is: revapi.convertAnalysisConfigurationFiles. | 
| <convertPomXml> | boolean | 0.9.0 | Whether to convert the analysisConfigurationelements
in pom.xml from JSON to XML or not.Default value is: true.User property is: revapi.convertPomXml. | 
| <disallowedExtensions> | String | 0.9.0 | Deprecated. since 0.11.0, use the pipelineConfigurationinsteadUser property is: revapi.disallowedExtensions. | 
| <expandProperties> | boolean | 0.11.6 | If set to true, the Maven properties will be expanded in the
configuration before it is supplied to Revapi. I.e. any ${var} appearing in the configuration values
will be replaced with the value of thevarproperty as
known to Maven. If the property is not defined, the expansion
doesn't take place.Default value is: false.User property is: revapi.expandProperties. | 
| <failBuildOnProblemsFound> | boolean | 0.9.0 | If true (the default), the maven plugin will fail the build when it
finds API problems (e.g. problems with with the criticality at
least equal to failCriticality).Default value is: true.User property is: revapi.failBuildOnProblemsFound. | 
| <failCriticality> | String | 0.12.0 | The minimum criticality of the found differences at which to fail
the build. This has to be one of the criticalities configured in
the pipeline configuration (if the pipeline configuration doesn't
define any, the following are the default ones: allowed,documented,highlight,error). If not defined, the
value is derived fromfailSeverityusing the
severity-to-criticality mapping (which is again configured in the
pipeline configuration. If not defined in the pipeline
configuration explicitly, the default mapping is the following:EQUIVALENT=allowed,NON_BREAKING=documented,POTENTIALLY_BREAKING=error,BREAKING= error.User property is: revapi.maximumCriticality. | 
| <failOnMissingConfigurationFiles> | boolean | 0.9.0 | Set to false if you want to tolerate files referenced in the analysisConfigurationFilesmissing on the filesystem
and therefore not contributing to the analysis configuration.The default is  Default value is: true.User property is: revapi.failOnMissingConfigurationFiles. | 
| <failOnUnresolvedArtifacts> | boolean | 0.9.0 | If true, the build will fail if one of the old or new artifacts
fails to be resolved. Defaults to false. Default value is: false.User property is: revapi.failOnUnresolvedArtifacts. | 
| <failOnUnresolvedDependencies> | boolean | 0.9.0 | If true, the build will fail if some of the dependencies of the old
or new artifacts fail to be resolved. Defaults to false. Default value is: false.User property is: revapi.failOnUnresolvedDependencies. | 
| <failSeverity> | FailSeverity | 0.9.0 | Deprecated. use the new failCriticalityDefault value is: potentiallyBreaking.User property is: revapi.failSeverity. | 
| <newArtifacts> | String[] | 0.9.0 | The coordinates of the new artifacts. These are the full GAVs of
the artifacts, which means that you can compare different artifacts
than the one being built. If you merely want to specify the
artifact being built, use newVersionproperty instead.User property is: revapi.newArtifacts. | 
| <newPromotedDependencies> | PromotedDependency[] | 0.13.6 | A list of dependencies of the new artifact(s) that should be
considered part of the new API. | 
| <newVersion> | String | 0.9.0 | The new version of the artifact. Defaults to "${project.version}". Default value is: ${project.version}.User property is: revapi.newVersion. | 
| <oldArtifacts> | String[] | 0.9.0 | The coordinates of the old artifacts. Defaults to single artifact
with the latest released version of the current project. If the this property is null, the  User property is: revapi.oldArtifacts. | 
| <oldPromotedDependencies> | PromotedDependency[] | 0.13.6 | A list of dependencies of the old artifact(s) that should be
considered part of the old API. | 
| <oldVersion> | String | 0.9.0 | If you don't want to compare a different artifact than the one
being built, specifying the just the old version is simpler way of
specifying the old artifact. The default value is "RELEASE" meaning that the old version is the last released version of the artifact being built (either remote or found locally (to account for artifacts installed into the local repo that are not available in some public remote repository)). The version of the compared artifact will be strictly older than the version of the new artifact. If you specify "LATEST", the old version will be resolved to the newest version available remotely, including snapshots (if found in one of the repositories active in the build). The version of the compared artifact will be either older or equal to the version of the new artifact in this case to account for comparing a locally built snapshot against the latest published snapshot. Default value is: RELEASE.User property is: revapi.oldVersion. | 
| <pipelineConfiguration> | PlexusConfiguration | 0.11.0 | The JSON or XML configuration of the extensions pipeline. This
enables the users easily specify which extensions should be
included/excluded in the Revapi analysis pipeline and also to
define transformation blocks - a way of grouping transforms
together to enable more fine grained control over how differences
are transformed. | 
| <promotedDependencies> | PromotedDependency[] | 0.13.6 | A list of dependencies of both the old and new artifact(s) that
should be considered part of the old/new API. This is a convenience
property if you just need to specify a set of dependencies to
promote into the API and that set can be specified in a way common
to both old and new APIs. If you need to specify different sets for
the old and new, use oldPromotedDependenciesornewPromotedDependenciesrespectively. IfoldPromotedDependenciesornewPromotedDependenciesare specified, they override
whatever is specified using this property.The individual properties of the dependency (e.g.
 E.g.  | 
| <resolveProvidedDependencies> | boolean | 0.9.0 | When establishing the API classes, Revapi by default also looks
through the provideddependencies. The reason for this
is that even though such dependencies do not appear in the
transitive dependency set established by maven, they need to be
present both on the compilation and runtime classpath of the
module. Therefore, the classes in the module are free to expose
classes from a provided dependency as API elements.In rare circumstances this is not a desired behavior though. It is undesired if for example the classes from the provided dependency are used only for establishing desired build order or when they are used in some non-standard scenarios during the build and actually not needed at runtime. Note that this property only influences the resolution of
provided dependencies of the main artifacts, not the transitively
reachable provided dependencies. For those, use the
 Default value is: true.User property is: revapi.resolveProvidedDependencies. | 
| <resolveTransitiveProvidedDependencies> | boolean | 0.9.0 | In addition to resolveProvidedDependenciesthis
property further controls how provided dependencies are resolved.
Using this property you can control how the indirect, transitively
reachable, provided dependencies are treated. The default is to not
consider them, which is almost always the right thing to do. It
might be necessary to set this property totruein the
rare circumstances where the API of the main artifacts includes
types from such transitively included provided dependencies. Such
occurrence will manifest itself by Revapi considering such types as
missing (which is by default reported as a potentially breaking
change). When you then resolve the transitive provided dependencies
(by setting this parameter to true), Revapi will be able to find
such types and do a proper analysis of them.Default value is: false.User property is: revapi.resolveTransitiveProvidedDependencies. | 
| <skip> | boolean | 0.9.0 | Whether to skip the mojo execution. Default value is: false.User property is: revapi.skip. | 
| <versionFormat> | String | 0.9.0 | If set, this property demands a format of the version string when
the oldVersionornewVersionparameters
are set toRELEASEorLATESTspecial
version strings.Because Maven will report the newest non-snapshot version as the
latest release, we might end up comparing a  This parameter is a regular expression pattern that the version
string needs to match in order to be considered a
 User property is: revapi.versionFormat. | 
boolean0.9.0Norevapi.alwaysCheckForReleaseVersiontrue<dependencies>.
Consult configuration
documentation for more details. 
These settings take precedence over the configuration loaded
from analysisConfigurationFiles.
org.codehaus.plexus.configuration.PlexusConfiguration0.9.0No<dependencies>. 
The analysisConfiguration can override the settings
present in the files.
The list is either a list of strings or has the following form:
  <analysisConfigurationFiles>
       <configurationFile>
           <path>path/to/the/file/relative/to/project/base/dir</path>
           <resource>path/to/the/file/in/one/of/the/dependencies</resource>
           <roots>
               <root>configuration/root1</root>
               <root>configuration/root2</root>
               ...
           </roots>
       </configurationFile>
       ...
   </analysisConfigurationFiles>
path is the path on the filesystem,resource is the path to the resource file in one
of the artifacts the plugin depends onroots is optional and specifies the subtrees of
the JSON/XML config that should be used for configuration. If not
specified, the whole file is taken into account.path or resource has to be
specified but not both. The configuration/root1 and
configuration/root2 are paths to the roots of the
configuration inside that JSON/XML config file. This might be used
in cases where multiple configurations are stored within a single
file and you want to use a particular one. 
An example of this might be a config file which contains API changes to be ignored in all past versions of a library. The classes to be ignored are specified in a configuration that is specific for each version:
   {
        "0.1.0" : [
            {
                "extension": "revapi.ignore",
                "configuration": [
                    {
                        "code" : "java.method.addedToInterface",
                        "new" : "method void com.example.MyInterface::newMethod()",
                        "justification" : "This interface is not supposed to be implemented by clients."
                    },
                    ...
                ]
            }
        ],
        "0.2.0" : [
            ...
        ]
    }
java.lang.Object[]0.9.0Norevapi.analysisConfigurationFilesHowever, setting this to false might be useful in situations where you have checked your dependencies in another module and don't want do that again. In that case, you might want to configure Revapi to ignore missing classes because it might find the classes from your dependencies as used in your API and would complain that it could not find it. See the docs.
boolean0.9.0Norevapi.checkDependenciestrueanalysisConfigurationFiles from JSON
to XML. 
Note that external configuration files with custom root elements are not supported, because it would not be clear how to convert the rest of the file into XML.
Also note that the original file will be left intact by the conversion and a new file with the same name and ".xml" extension will be created in the same directory and the pom.xml will be updated to point to this new file. You should delete the old file after making sure the conversion went fine.
boolean0.9.0Norevapi.convertAnalysisConfigurationFilesfalseanalysisConfiguration elements
in pom.xml from JSON to XML or not.boolean0.9.0Norevapi.convertPomXmltruepipelineConfiguration insteadYou can modify this set if you use another extensions that change the found differences in a way that the determined new version would not correspond to what it should be.
java.lang.String0.9.0Norevapi.disallowedExtensions${var} appearing in the configuration values
will be replaced with the value of the var property as
known to Maven. If the property is not defined, the expansion
doesn't take place.boolean0.11.6Norevapi.expandPropertiesfalsefailCriticality).boolean0.9.0Norevapi.failBuildOnProblemsFoundtrueallowed, documented,
highlight, error). If not defined, the
value is derived from failSeverity using the
severity-to-criticality mapping (which is again configured in the
pipeline configuration. If not defined in the pipeline
configuration explicitly, the default mapping is the following:
EQUIVALENT = allowed,
NON_BREAKING = documented,
POTENTIALLY_BREAKING = error,
BREAKING = error.java.lang.String0.12.0Norevapi.maximumCriticalityanalysisConfigurationFiles missing on the filesystem
and therefore not contributing to the analysis configuration. 
The default is true, which means that a missing
analysis configuration file will fail the build.
boolean0.9.0Norevapi.failOnMissingConfigurationFilestrueboolean0.9.0Norevapi.failOnUnresolvedArtifactsfalseboolean0.9.0Norevapi.failOnUnresolvedDependenciesfalsefailCriticalityorg.revapi.maven.FailSeverity0.9.0Norevapi.failSeveritypotentiallyBreakingnewVersion property instead.java.lang.String[]0.9.0Norevapi.newArtifactsorg.revapi.maven.PromotedDependency[]0.13.6Nojava.lang.String0.9.0Norevapi.newVersion${project.version}If the this property is null, the oldVersion
property is checked for a value of the old version of the artifact
being built.
java.lang.String[]0.9.0Norevapi.oldArtifactsorg.revapi.maven.PromotedDependency[]0.13.6NoThe default value is "RELEASE" meaning that the old version is the last released version of the artifact being built (either remote or found locally (to account for artifacts installed into the local repo that are not available in some public remote repository)). The version of the compared artifact will be strictly older than the version of the new artifact.
If you specify "LATEST", the old version will be resolved to the newest version available remotely, including snapshots (if found in one of the repositories active in the build). The version of the compared artifact will be either older or equal to the version of the new artifact in this case to account for comparing a locally built snapshot against the latest published snapshot.
java.lang.String0.9.0Norevapi.oldVersionRELEASEorg.codehaus.plexus.configuration.PlexusConfiguration0.11.0NooldPromotedDependencies or
newPromotedDependencies respectively. If
oldPromotedDependencies or
newPromotedDependencies are specified, they override
whatever is specified using this property. 
The individual properties of the dependency (e.g.
groupId, artifactId,
version, type or classifier)
are matched exactly. If you enclose the value in forward slashes,
they are matched as regular expressions instead.
E.g. <groupId>com.acme</groupId> will
only match dependencies with that exact groupId, while
<groupId>/com\.acme(\..*)?/</groupId> will
match "com.acme" groupId or any "sub-groupId" thereof
(e.g. "com.acme.utils", etc.) using a regular expression.
org.revapi.maven.PromotedDependency[]0.13.6Noprovided dependencies. The reason for this
is that even though such dependencies do not appear in the
transitive dependency set established by maven, they need to be
present both on the compilation and runtime classpath of the
module. Therefore, the classes in the module are free to expose
classes from a provided dependency as API elements. 
In rare circumstances this is not a desired behavior though. It is undesired if for example the classes from the provided dependency are used only for establishing desired build order or when they are used in some non-standard scenarios during the build and actually not needed at runtime.
Note that this property only influences the resolution of
provided dependencies of the main artifacts, not the transitively
reachable provided dependencies. For those, use the
resolveTransitiveProvidedDependencies parameter.
boolean0.9.0Norevapi.resolveProvidedDependenciestrueresolveProvidedDependencies this
property further controls how provided dependencies are resolved.
Using this property you can control how the indirect, transitively
reachable, provided dependencies are treated. The default is to not
consider them, which is almost always the right thing to do. It
might be necessary to set this property to true in the
rare circumstances where the API of the main artifacts includes
types from such transitively included provided dependencies. Such
occurrence will manifest itself by Revapi considering such types as
missing (which is by default reported as a potentially breaking
change). When you then resolve the transitive provided dependencies
(by setting this parameter to true), Revapi will be able to find
such types and do a proper analysis of them.boolean0.9.0Norevapi.resolveTransitiveProvidedDependenciesfalseboolean0.9.0Norevapi.skipfalseoldVersion or newVersion parameters
are set to RELEASE or LATEST special
version strings. 
Because Maven will report the newest non-snapshot version as the
latest release, we might end up comparing a .Beta or
other pre-release versions with the new version. This might not be
what you want and setting the versionFormat will make sure that a
newest version conforming to the version format is used instead of
the one resolved by Maven by default.
This parameter is a regular expression pattern that the version
string needs to match in order to be considered a
RELEASE.
java.lang.String0.9.0Norevapi.versionFormat