首页 > 解决方案 > 在预编译项目上使用 Maven 运行测试

问题描述

使用 Maven,我想在预编译/预jar 的多模块项目上运行单元和集成测试。我发现这非常困难。

我的业务案例是,我想在一个地方编译和打包一个多模块 Maven 项目,然后使用不同的 Java 版本和在不同的操作系统上运行单元测试和集成测试,以检查兼容性。让我们说 {Java 8, Java 10} x {Ubuntu, Windows} 以保持简单。

我想以一种速度编译和 jar 的原因是,我想确保我对交付的实际代码运行测试。如果我到处重新编译,我担心我可能会在不知不觉中引入错误。

一种解决方案是mvn deploy -DaltDeploymentRepository=$mydir在 Ubuntu 上生成一个已编译的项目树和一个充满 jar 的目录;然后压缩项目树和部署目录并将它们发送到 Windows 机器;并mvn surefire:test -Dmaven.repo.local=$mydir在项目树上运行。

这行得通,但它很笨拙。Surefire 似乎读取了项目树中的测试类,并使用同一项目中的类 + 来自部署 repo 的 jar 依赖项进行链接。存在一个问题,-Dmaven.repo.localMaven 需要再次下载所有第 3 方依赖项,因为该 repo 仅包含我的项目工件。所以一个可靠的解决方案,但不是很好。

相反,我一直在尝试做的是,只需使用已编译的项目树:

有趣的是,它不是确定性的,失败发生在不同的阶段,有时根本没有——我偶尔会得到绿色构建!

现在我束手无策:我一直认为这应该很简单,而且我不可能成为第一个为这个简单问题而苦苦挣扎的人。

反应堆会发生什么,何时以及如何触发对我来说是不透明的。依赖关系图必须格式正确,否则无法编译。那么为什么我不能让 Maven 为运行测试重现相同的依赖关系图呢?

问候,

拉斯

PS:这与我尊敬的同事 Ben 也遇到的问题有关:如何在多模块 Maven 项目中构建所有模块后运行集成测试?

标签: javamavenunit-testingtestingmaven-surefire-plugin

解决方案


为此使用构建服务器(Jenkins)怎么样?

如果您有复杂的测试场景,您最好先构建(使用 Maven),然后运行管道的另一个步骤,将文件部署到正确的服务器/测试系统并开始测试。


推荐阅读