Revapi Java-based extensions test support

Contains utilities to ease testing extensions processing java code. Makes it easy to compile custom source files and subsequently analyze the compiled code using the java annotation processing APIs.

License

License

Categories

Categories

Java Languages
GroupId

GroupId

org.revapi
ArtifactId

ArtifactId

revapi-java-test-support
Last Version

Last Version

0.2.2
Release Date

Release Date

Type

Type

jar
Description

Description

Revapi Java-based extensions test support
Contains utilities to ease testing extensions processing java code. Makes it easy to compile custom source files and subsequently analyze the compiled code using the java annotation processing APIs.
Project Organization

Project Organization

Lukas Krejci
Source Code Management

Source Code Management

https://github.com/revapi/revapi

Download revapi-java-test-support

How to add to project

<!-- https://jarcasting.com/artifacts/org.revapi/revapi-java-test-support/ -->
<dependency>
    <groupId>org.revapi</groupId>
    <artifactId>revapi-java-test-support</artifactId>
    <version>0.2.2</version>
</dependency>
// https://jarcasting.com/artifacts/org.revapi/revapi-java-test-support/
implementation 'org.revapi:revapi-java-test-support:0.2.2'
// https://jarcasting.com/artifacts/org.revapi/revapi-java-test-support/
implementation ("org.revapi:revapi-java-test-support:0.2.2")
'org.revapi:revapi-java-test-support:jar:0.2.2'
<dependency org="org.revapi" name="revapi-java-test-support" rev="0.2.2">
  <artifact name="revapi-java-test-support" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.revapi', module='revapi-java-test-support', version='0.2.2')
)
libraryDependencies += "org.revapi" % "revapi-java-test-support" % "0.2.2"
[org.revapi/revapi-java-test-support "0.2.2"]

Dependencies

compile (2)

Group / Artifact Type Version
junit : junit jar 4.11
org.slf4j : slf4j-api jar 1.7.5

provided (2)

Group / Artifact Type Version
org.revapi : revapi-site-shared zip 3
com.google.code.findbugs : annotations jar 3.0.0

Project Modules

There are no modules declared in this project.

Revapi

Build Status Code Coverage Gitter Chat

Revapi is a tool for API analysis and change tracking.

INFO: Revapi requires Java8 update 40 (1.8.0_40) or later to run. Older versions may produce wrong results.

Summary

While Revapi is designed to be extensible and in theory should support API checks in other languages than Java (not just programming languages but anything that can be decomposed to a tree structure) the only extension in existence today is the Java API checker.

The main distinguishing features of the Java API checker include:

  • large number of API checks

    • categorized by their influence on source, binary and "semantical" compatibility

  • support for computing the API "surface" by tracking usages of types across the checked library and also its dependencies (ability to report type "leakage" from deps)

  • support for Java8 constructs (default methods in particular)

  • powerful filtering stuff to check and reclassification of found problems

  • ability to filter by annotation presence

  • Maven plugin automatically includes depenendcies in the check

Other features:

  • ability to judge the severity of changes based on semver rules (see here)

  • automatic updates of pom.xml or release.properties versions according to semver rules (see here)

  • pluggable reporting (standard output, maven site generation, JUnit report generator (TBD))

Building

This is a maven project, so to build you simply:

mvn install

Usage

Revapi can be invoked in a couple of ways. It can be used as a standalone program, as a maven plugin or it can also be embedded in your application and used as a library.

Standalone

Download the standalone distribution zip and

unzip revapi-XXX-standalone.zip
cd revapi-XXX-standalone
./revapi.sh

Read the usage info and go.

Maven

<build>
    <plugins>
        <plugin>
            <groupId>org.revapi</groupId>
            <artifactId>revapi-maven-plugin</artifactId>
            <version>...</version>
            <dependencies>
                <dependency>
                    <groupId>org.revapi</groupId>
                    <artifactId>revapi-java</artifactId>
                    <version>...</version>
                </dependency>
                <dependency>
                    <groupId>com.acme</groupId>
                    <artifactId>my-extension</artifactId>
                    <version>...</version>
                </dependency>
                ...
            </dependencies>
            <configuration>
                ...
            </configuration>
            <executions>
                <execution>
                    <id>api-check</id>
                    <goals><goal>check</goal></goals>
                    ...
                </execution>
                ...
            </executions>
        </plugin>
        ...
    </plugins>
    ...
</build>

Gradle

There is an external Gradle plugin available for Revapi, https://github.com/palantir/gradle-revapi.

Embedding

Revapi revapi = Revapi.builder().withAllExtensionsFromThreadContextClassLoader().build();

AnalysisContext analysisContext = AnalysisContext.builder()
    .withOldAPI(API.of(...))
    .withNewAPI(API.of(...))
    .withConfigurationFromJSON("json").build();

revapi.analyze(analysisContext);

Extending Revapi

See the site for more info.

org.revapi

Revapi

Revapi - API evolution checker for the masses

Versions

Version
0.2.2
0.2.1
0.2.0
0.1.0