使用 maven surefire 使用 mpirun 运行 Junit 测试

Posted

技术标签:

【中文标题】使用 maven surefire 使用 mpirun 运行 Junit 测试【英文标题】:Running Junit tests with mpirun using maven surefire 【发布时间】:2020-07-25 21:39:21 【问题描述】:

我想使用 mpirun -n 4 java <relevant arguments>、very similar to what was discussed in this question 进行一些 Junit 测试,但使用 maven surefire 而不是 ant。

从上一个问题中的 cmets 看来,OP 似乎能够通过创建一个专用脚本并让他的 ant 脚本的 junit 部分的 jvm 参数引用该脚本来实现这一点。

我的问题是:maven firesafe 中是否存在等效功能?可以让我将用于任意脚本的“java”命令更改为什么?或者我应该创建一个特定的 ant 脚本来从 maven 调用?

这是我的pom.xml 文件的摘录:

         <plugin>
           <artifactId>maven-surefire-plugin</artifactId>
           <version>2.22.1</version>
           <configuration>
             <!-- Specify a script with a relative path here ? -->
           </configuration>
         </plugin>

【问题讨论】:

【参考方案1】:

经过一番努力,我最终得到了一个与我预期完全不同的解决方案。

我开发了自己的 Junit4 运行器,它为我创建了正确的 mpirun -np X java -cp... 命令并解析每个等级的测试结果。

由于使用自定义运行器是 Junit4 的标准功能,它可以与运行 Junit 测试的任何环境无缝集成,包括我特别感兴趣的 Maven Surefire(和 Failsafe)插件。

我不会开发这个自定义 Junit 运行器如何工作的实现细节,但如果你有兴趣,我刚刚在 GitHub 上发布了它(网站:https://handist.github.io/mpi-junit/)。

【讨论】:

以上是关于使用 maven surefire 使用 mpirun 运行 Junit 测试的主要内容,如果未能解决你的问题,请参考以下文章

在 Visual Studio 中的 Windows 上安装 MPIR 时遇到问题?

如何将基于mpir库的VC9.0代码转换为Matlab mex函数?

Invalid plugin descriptor for org.apache.maven.plugins:maven-surefire-plugin:2.7.2

使用 CentOS 6.4 在 Python 2.7 上修复“警告:未找到 GMP 或 MPIR 库;未构建 Crypto.PublickKey._fastmath”错误

JUnit 和 Surefire 并行测试 - ForkCount 和 ThreadCount

使用 tycho-surefire-plugin 运行单个插件测试方法