/spotjmhbugs

A SpotBugs plugin that detects bad practices on JMH microbenchmarks.

Primary LanguageJavaMIT LicenseMIT

SpotJMHBugs

Build Status

A SpotBugs plugin for static analysis on JMH performance tests.

Getting Started

These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.

Prerequisites

To build the performance-tests-checker plugin you just need Java and Maven.

Java 8 or higher

Building

You can use Maven to generate the jar file necessary for deployment.

First compile the source of the project

./mvnw compile

And simply pack the compiled code into the jar format. This jar will then be used to integrate our rules to SpotBugs program.

./mvnw package

Deployment to SpotBugs

There are multiple ways of using SpotJMHBugs in your environment. For a detailed explanation, please refer to the official FindBugs documentation.

Adding to Eclipse Plugin

It is possible to configure custom detectors via Eclipse workspace preferences. Go to Window->Preferences->Java->FindBugs->Misc. Settings->Custom Detectors and specify there the jar of the performance-tests-checker.

Deploying with SpotBugs

SpotBugs uses a plugin-based approach to adding detectors. This makes it easy for users to add their own detectors alongside the ones that come built in.

  1. First download the latest SpotBugs binary release at the SpotBugs official website. The only dependencies required for SpotBugs is a Java version properly installed.

  2. Extract the zip/rar SpotBugs and configure the environment variable SPOTBUGS_HOME to the extracted directory.

  3. Copy the built (see Building instructions above) spotJMHbugs.jar to the plugin folder of the SpotBugs.

  4. Execute the $SPOTBUGS_HOME/lib/spotbugs.jar with the -textui command line to get the list of all possible line commands of SpotBugs.

  5. To make sure that you have deployed a valid plugin jar, you can run the command java -jar $SPOTBUGS_HOME/lib/spotbugs.jar -textui -showPlugins. The performance-checker plugin should be listed in the Available plugins.

Usage with spotbugs-maven-plugin

To fail maven build of your JMH-project if there are some bugs spotted, add to the root of the probject file spotbugs-exclude.xml with content:

<FindBugsFilter>
    <Match>
        <Class name="~.*jmhTest"/>
    </Match>
    <Match>
        <Class name="~.*jmhType.*"/>
    </Match>
    <Match>
        <Bug pattern="JMH_BENCHMARK_METHOD_FOUND"/>
    </Match>
</FindBugsFilter>

It is needed to exclude generated jmh classes from analysis and to exclude noop-pattern that will always fail your build (will be removed in #5)

Than add to you pom.xml to the build plugins

<plugin>
    <groupId>com.github.spotbugs</groupId>
    <artifactId>spotbugs-maven-plugin</artifactId>
    <version>3.1.12</version>
    <executions>
        <execution>
            <id>spotbugs</id>
            <goals>
                <goal>check</goal>
            </goals>
        </execution>
    </executions>
    <configuration>
        <excludeFilterFile>spotbugs-exclude.xml</excludeFilterFile>
        <fork>false</fork>
        <plugins>
            <plugin>
                <groupId>de.heidelberg.pvs.diego</groupId>
                <artifactId>spotJMHbugs</artifactId>
                <version>1.0-SNAPSHOT</version>
            </plugin>
        </plugins>
    </configuration>
</plugin>

After that running verify stage will check your jmh-project and fail the build if there are any bugs (from the core of spotbugs project and specfic to JMH spotted by this project)

Bad JMH Practices

Our plugin detects five bad practices related to benchmark creation:

  • Not using returned computation (RETU)
  • Using accumulation to consume values inside a loop (LOOP)
  • Using final primitive for benchmark inputs (FINAL)
  • Running fixture methods for each benchmark method invocation (INVO)
  • Configuring benchmarks with zero forks (FORK)

For more details on each of the above mentioned bad practices, please refer to our TSE paper

Authors