Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add revapi as option during build #11277

Merged
merged 1 commit into from
Aug 13, 2020
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
137 changes: 137 additions & 0 deletions build-parent/pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -100,6 +100,21 @@

<boring-ssl.version>2.0.30.Final</boring-ssl.version>

<!-- revapi API check -->
<revapi-maven-plugin.version>0.12.1</revapi-maven-plugin.version>
<revapi-java-plugin.version>0.22.0</revapi-java-plugin.version>
<build-helper-plugin.version>1.9.1</build-helper-plugin.version>
<revapi-reporter-text.version>0.12.1</revapi-reporter-text.version>
<revapi-reporter-json.version>0.2.1</revapi-reporter-json.version>
<!-- Latest release to be used by api-compatibility-check to check backwards compatibility of the Quarkus API. -->
<revapi.oldVersion>1.6.0.Final</revapi.oldVersion>
<revapi.newVersion>${project.version}</revapi.newVersion>
<!-- severity Possible values: equivalent, nonBreaking, potentiallyBreaking, breaking -->
<revapi.reportSeverity>nonBreaking</revapi.reportSeverity>
<!-- Skip the API checks by default. Let the modules opt in. -->
<revapi.skip>true</revapi.skip>
<!-- By default don't check dependencies -->
<revapi.checkdeps>false</revapi.checkdeps>
</properties>

<dependencyManagement>
Expand Down Expand Up @@ -495,6 +510,16 @@
</dependency>
</dependencies>
</plugin>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>build-helper-maven-plugin</artifactId>
<version>${build-helper-plugin.version}</version>
</plugin>
<plugin>
<groupId>org.revapi</groupId>
<artifactId>revapi-maven-plugin</artifactId>
<version>${revapi-maven-plugin.version}</version>
</plugin>
</plugins>
</pluginManagement>
</build>
Expand Down Expand Up @@ -818,5 +843,117 @@
</plugins>
</build>
</profile>

<profile>
<id>api-check</id>
<activation>
<activeByDefault>false</activeByDefault>
</activation>
<build>
<plugins>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>build-helper-maven-plugin</artifactId>
<executions>
<execution>
<id>parse-version</id>
<goals>
<goal>parse-version</goal>
</goals>
<phase>validate</phase>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.revapi</groupId>
<artifactId>revapi-maven-plugin</artifactId>
<dependencies>
<dependency>
<groupId>io.quarkus</groupId>
<artifactId>quarkus-revapi-config</artifactId>
<version>${project.version}</version>
</dependency>
<dependency>
<groupId>org.revapi</groupId>
<artifactId>revapi-java</artifactId>
<version>${revapi-java-plugin.version}</version>
</dependency>
<dependency>
<groupId>org.revapi</groupId>
<artifactId>revapi-reporter-json</artifactId>
<version>${revapi-reporter-json.version}</version>
</dependency>
<dependency>
<groupId>org.revapi</groupId>
<artifactId>revapi-reporter-text</artifactId>
<version>${revapi-reporter-text.version}</version>
</dependency>
</dependencies>
<configuration>
<oldArtifacts>
<artifact>${project.groupId}:${project.artifactId}:${revapi.oldVersion}</artifact>
</oldArtifacts>
<newArtifacts>
<artifact>${project.groupId}:${project.artifactId}:${revapi.newVersion}</artifact>
</newArtifacts>
<!-- don't fail is false making it possible to have
revapi checks without requiring config files -->
<failOnMissingConfigurationFiles>false</failOnMissingConfigurationFiles>
<!-- Consider changes from the latest .Final version,
not from the latest non-snapshot. -->
<versionFormat>\d+\.\d+\.\d+\.Final</versionFormat>
<!-- By default revapi will check the oldArtifact
against the currently executed build -->
<!-- <checkDependencies>false</checkDependencies> -->
<analysisConfigurationFiles>
<configurationFile>
<resource>revapi/revapi-configuration.xml</resource>
</configurationFile>
<configurationFile>
<path>api-changes.xml</path>
<roots>
<root>versions/v${parsedVersion.majorVersion}.${parsedVersion.minorVersion}.${parsedVersion.incrementalVersion}</root>
</roots>
</configurationFile>
</analysisConfigurationFiles>
<!-- By default, revapi will only fail the build
if there are potentially breaking or breaking changes. However, in the report
we want even non breaking changes to be present. -->
<reportSeverity>nonBreaking</reportSeverity>
<failSeverity>potentiallyBreaking</failSeverity>
<failBuildOnProblemsFound>true</failBuildOnProblemsFound>
<checkDependencies>${revapi.checkdeps}</checkDependencies>
<ignoreSuggestionsFormat>xml</ignoreSuggestionsFormat>
<ignoreSuggestionsFile>${project.build.directory}/api-changes-suggestions.xml</ignoreSuggestionsFile>
<expandProperties>true</expandProperties>
</configuration>
<!-- Running two executions is a workaround to make sure
we get a HTML report in case revapi finds some incompatible changes. The
"check" goal will simply fail the whole build before it could get to the
report. To make sure we always get a HTML report, the "report" goal needs
to be executed before the "check" goal. Once https://github.com/revapi/revapi/issues/11
is fixed it should be possible to use single execution. -->
<executions>
<execution>
<id>api-check</id>
<goals>
<goal>check</goal>
</goals>
<phase>verify</phase>
</execution>
<execution>
<!-- report can be found in ${build.directory}/site/revapi-report.html -->
<id>api-report</id>
<goals>
<goal>report</goal>
</goals>
<phase>package</phase>
</execution>
</executions>
</plugin>
</plugins>
</build>
</profile>

</profiles>
</project>
38 changes: 38 additions & 0 deletions independent-projects/revapi/pom.xml
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
<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>
<parent>
<groupId>org.jboss</groupId>
<artifactId>jboss-parent</artifactId>
<version>36</version>
</parent>

<groupId>io.quarkus</groupId>
<artifactId>quarkus-revapi-config</artifactId>
<name>Quarkus revapi configuration</name>
<version>999-SNAPSHOT</version>
<description>Contains the configuration of the Revapi API checker and the list of the API changes
in the Quarkus APIs.
</description>
<packaging>jar</packaging>

<properties>
<format.skip>true</format.skip>
</properties>

<build>
<plugins>
<!--
This is not deployed into a Maven repository. It is merely installed into the local Maven repository
during a local build.
-->
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-deploy-plugin</artifactId>
<configuration>
<skip>true</skip>
</configuration>
</plugin>
</plugins>
</build>
</project>
49 changes: 49 additions & 0 deletions independent-projects/revapi/src/main/resources/META-INF/revapi.ftl
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
<#ftl strip_whitespace=true>
<#if reports?has_content>
# API Change analysis Results

The summary of the API changes between artifacts <#list analysis.oldApi.archives as archive>`${archive.name}`<#sep>, </#list> and
<#list analysis.newApi.archives as archive>`${archive.name}`<#sep>, </#list>

[cols="1,1,1,1,1", options="header"]
.Changes
|===
|Code
|Element
|Classification
|Description
|Justification

<#list reports as report>

<#list report.differences as diff>

|${diff.code}
|<#if report.newElement??>*${report.newElement}*</#if>
<#if report.oldElement??>*${report.oldElement}*</#if>
<#if diff.attachments['exampleUseChainInNewApi']??>
Example use chain in new api:
<#list diff.attachments['exampleUseChainInNewApi']?split(" <- ") as e>
<-${e}
</#list>
</#if>
<#if diff.attachments['exampleUseChainInOldApi']?? && diff.attachments['exampleUseChainInNewApi']! != diff.attachments['exampleUseChainInOldApi']>
Example use chain in old api:
<#list diff.attachments['exampleUseChainInOldApi']?split(" <- ") as e>
<-${e}
</#list>
</#if>

<#list diff.attachments?keys as key>
<#if !['newArchive', 'newArchiveRole', 'oldArchive', 'oldArchiveRole','package','classQualifiedName','classSimpleName','elementKind','exception','methodName','exampleUseChainInNewApi','exampleUseChainInOldApi','fieldName']?seq_contains(key)>
${key} = ${diff.attachments[key]}
</#if>
</#list>
|<#list diff.classification?keys as compat><#if diff.classification?api.get(compat) != "NON_BREAKING"> ${compat?capitalize}: ${diff.classification?api.get(compat)?capitalize?replace("_","")}${'\n'}</#if></#list>
|${diff.description}
|${diff.justification!""}

</#list>
</#list>
|===
</#if>
Original file line number Diff line number Diff line change
@@ -0,0 +1,31 @@
<?xml version='1.0' encoding='UTF-8'?>
<!-- The basic configuration for Revapi API checks in all modules that have API checks enabled. -->
<analysisConfiguration>
<revapi.java>
<missing-classes>
<behavior>error</behavior>
<ignoreMissingAnnotations>true</ignoreMissingAnnotations>
</missing-classes>
<filter>
<packages>
<regex>true</regex>
<exclude><item>javax\..*</item></exclude>
</packages>
</filter>
</revapi.java>
<!-- <revapi.reporter.text id="stdout">
<output>out</output>
<template>revapi.ftl</template>
</revapi.reporter.text> -->
<revapi.reporter.text>
<minSeverity>NON_BREAKING</minSeverity>
<output>${project.build.directory}/revapi-results/revapi-breakages.adoc</output>
<template>revapi.ftl</template>
</revapi.reporter.text>
<revapi.reporter.json>
<minSeverity>NON_BREAKING</minSeverity>
<output>${project.build.directory}/revapi-results/revapi-breakages.json</output>
<indent>true</indent>
<keepEmptyFile>true</keepEmptyFile>
</revapi.reporter.json>
</analysisConfiguration>
1 change: 1 addition & 0 deletions pom.xml
Original file line number Diff line number Diff line change
Expand Up @@ -44,6 +44,7 @@

<!-- External projects -->
<module>independent-projects/ide-config</module>
<module>independent-projects/revapi</module>
<module>independent-projects/arc</module>
<module>independent-projects/bootstrap</module>
<module>independent-projects/qute</module>
Expand Down