JMH 没有 运行 在 Java 模块内(无法找到资源:/META-INF/BenchmarkList)
JMH doesn't run inside a Java Module (Unable to find the resource: /META-INF/BenchmarkList)
我参加了一个使用 maven-surefire-plugin
(自动化测试)触发 JMH 基准测试的项目,并向其中添加了 module-info.java
。现在,不再生成 META-INF/BenchmarkList
(事实上,整个目录都丢失了)所以我在启动基准测试时遇到以下错误:
ERROR: Unable to find the resource: /META-INF/BenchmarkList
我怀疑 Java 模块阻止注释处理器正确地 运行,但我不知道如何修复它。有什么想法吗?
我通过反复试验弄明白了。它看起来像是 maven-compiler-plugin 3.8.0 中的错误(或 "feature")。当存在 module-info.java
时,不再自动拾取 JMH 注释处理器。添加此配置为我解决了问题:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
[...]
<annotationProcessorPaths>
<path>
<groupId>org.openjdk.jmh</groupId>
<artifactId>jmh-generator-annprocess</artifactId>
<version>${jmh.version}</version>
</path>
</annotationProcessorPaths>
[...]
</configuration>
</plugin>
更新:我针对 maven-compiler-plugin 提交了 bug report。
我参加了一个使用 maven-surefire-plugin
(自动化测试)触发 JMH 基准测试的项目,并向其中添加了 module-info.java
。现在,不再生成 META-INF/BenchmarkList
(事实上,整个目录都丢失了)所以我在启动基准测试时遇到以下错误:
ERROR: Unable to find the resource: /META-INF/BenchmarkList
我怀疑 Java 模块阻止注释处理器正确地 运行,但我不知道如何修复它。有什么想法吗?
我通过反复试验弄明白了。它看起来像是 maven-compiler-plugin 3.8.0 中的错误(或 "feature")。当存在 module-info.java
时,不再自动拾取 JMH 注释处理器。添加此配置为我解决了问题:
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
[...]
<annotationProcessorPaths>
<path>
<groupId>org.openjdk.jmh</groupId>
<artifactId>jmh-generator-annprocess</artifactId>
<version>${jmh.version}</version>
</path>
</annotationProcessorPaths>
[...]
</configuration>
</plugin>
更新:我针对 maven-compiler-plugin 提交了 bug report。