java - 在预编译项目上使用 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.local
Maven 需要再次下载所有第 3 方依赖项,因为该 repo 仅包含我的项目工件。所以一个可靠的解决方案,但不是很好。
相反,我一直在尝试做的是,只需使用已编译的项目树:
- 如果我只是这样做,
mvn surefire:test
我会遇到解决依赖关系的问题 - 我试图
mvn compile -Dmaven.main.skip surefire:test
修复依赖解析,这似乎有效 - 只是不适用于测试依赖 - 我进一步尝试
mvn compile -Dmaven.main.skip test-compile -Dmaven.test.skip surefire:test
了,但由于某种原因也不起作用,构建再次尝试解决测试依赖项失败。
有趣的是,它不是确定性的,失败发生在不同的阶段,有时根本没有——我偶尔会得到绿色构建!
现在我束手无策:我一直认为这应该很简单,而且我不可能成为第一个为这个简单问题而苦苦挣扎的人。
反应堆会发生什么,何时以及如何触发对我来说是不透明的。依赖关系图必须格式正确,否则无法编译。那么为什么我不能让 Maven 为运行测试重现相同的依赖关系图呢?
问候,
拉斯
PS:这与我尊敬的同事 Ben 也遇到的问题有关:如何在多模块 Maven 项目中构建所有模块后运行集成测试?
解决方案
为此使用构建服务器(Jenkins)怎么样?
如果您有复杂的测试场景,您最好先构建(使用 Maven),然后运行管道的另一个步骤,将文件部署到正确的服务器/测试系统并开始测试。
推荐阅读
- node.js - 无法安装正确的 Angular/CLI 版本
- r - 带有分类轴和数值轴的条形图
- android - 是否可以在 dialogFragment 上绘制 ShowCaseView?
- frontend-maven-plugin - 通过本地工件安装 NPM/节点
- java - 如何根据 Lettuce 中的配置选择多个 Redis 连接 - Standalone、RedisCluster 和 Sentinel。?
- javascript - 数组中的对象是否通过引用传递?
- r - 洗牌的非正态抽样
- c# - 如何为多个页面重用模型的一部分
- google-contacts-api - 在谷歌表格中填写一行时如何设置第一行始终为空
- amazon-web-services - StackSets 创建的 CloudFormation 堆栈起源于哪里?