使用 Maven,我想在预编译/预 jar 的多模块项目上运行单元和集成测试。我发现这非常困难。
我的业务案例是,我想在一个地方编译和打包一个多模块 Maven 项目,然后使用不同的 Java 版本在不同的操作系统上运行单元测试和集成测试,以检查兼容性。为了简单起见,我们只说 {Java 8、Java 10} x {Ubuntu、Windows}。
我想同时编译和 jar up 的原因是,我想确保我对交付的实际代码运行测试。如果我在所有地方都重新编译,我担心我可能会无意中引入错误。
一个解决方案是在 Ubuntu 上执行 mvn deploy -DaltDeploymentRepository=$mydir
以生成编译的项目树和一个充满 jar 的目录;然后压缩项目树和部署目录并将它们发送到 Windows 机器;并在项目树上运行 mvn surefire:test -Dmaven.repo.local=$mydir
。
这行得通,但它很笨拙。 Surefire 似乎读取了项目树中的测试类,并使用同一项目中的类 + 部署仓库中的 jar 依赖项进行链接。存在一个问题,使用 -Dmaven.repo.local
Maven 需要再次下载所有第 3 方依赖项,因为该 repo 仅包含我的项目 Artifact 。这是一个可靠的解决方案,但不是很好。
相反,我一直在尝试做的是,只使用已编译的项目树:
- 如果我只是执行
mvn surefire:test
我会在解决依赖关系时遇到问题 - 我已经尝试使用
mvn compile -Dmaven.main.skip surefire:test
来修复依赖解析,这似乎有效 - 只是不适用于测试依赖 - 我进一步尝试了
mvn compile -Dmaven.main.skip test-compile -Dmaven.test.skip surefire:test
,但由于某种原因也不起作用,构建再次尝试失败解决测试依赖关系。
有趣的是,它不是确定性的,失败发生在不同的阶段,有时根本不会发生——我偶尔会得到绿色构建!
现在我束手无策:我一直认为这应该很简单,而且我不可能是第一个为这个简单问题苦苦挣扎的人。
react 堆会发生什么,何时以及如何触发对我来说是不透明的。依赖关系图必须格式正确,否则无法编译。那么为什么我不能让 Maven 为运行测试重现相同的依赖关系图呢?
问候,
拉瑟
PS:这与我尊敬的同事 Ben 也遇到的问题有关:How can I run integration tests after building all modules in a multi-module Maven project?
最佳答案
为此使用构建服务器 (Jenkins) 怎么样?
如果您有复杂的测试场景,您最好先构建(使用 Maven),然后运行管道的另一个步骤,将文件部署到正确的服务器/测试系统并开始测试。
关于java - 在预编译项目上使用 Maven 运行测试,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51079816/