A SpotBugs plugin for static analysis on JMH performance tests.
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes.
To build the performance-tests-checker plugin you just need Java and Maven.
Java 8 or higher
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
There are multiple ways of using SpotJMHBugs in your environment. For a detailed explanation, please refer to the official FindBugs documentation.
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.
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.
-
First download the latest SpotBugs binary release at the SpotBugs official website. The only dependencies required for SpotBugs is a Java version properly installed.
-
Extract the zip/rar SpotBugs and configure the environment variable
SPOTBUGS_HOME
to the extracted directory. -
Copy the built (see Building instructions above)
spotJMHbugs.jar
to theplugin
folder of the SpotBugs. -
Execute the
$SPOTBUGS_HOME/lib/spotbugs.jar
with the-textui
command line to get the list of all possible line commands of SpotBugs. -
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.
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)
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