使用Maven,我想在预编译/预打包的多模块项目上运行单元和集成测试。我发现这非常困难。
我的业务案例是,我想在一个地方编译并打包一个多模块Maven项目,然后使用不同的Java版本和不同的操作系统运行单元测试和集成测试,以检查兼容性。为了简单起见,我们只说{Java 8,Java 10} x {Ubuntu,Windows}。
我要一步步编译和调试的原因是,我想确保对实际交付的代码运行测试。如果我到处重新编译,我担心会不经意间引入错误。
一种解决方案是在Ubuntu上进行mvn deploy -DaltDeploymentRepository=$mydir
,以生成已编译的项目树和一个充满jar的目录;然后压缩项目树并部署目录,然后将其传送到Windows计算机;然后在项目树上运行mvn surefire:test -Dmaven.repo.local=$mydir
。
那行得通,但是真是笨拙。 Surefire似乎读取项目树中的测试类,并使用来自部署库的相同项目+ jar依赖项中的类进行链接。存在一个问题,-Dmaven.repo.local
的Maven需要再次下载所有第三方的依赖,因为该仓库仅包含我的项目工件。这样的解决方案固然不错,但不是很好。
相反,我一直想做的只是使用编译后的项目树:
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遇到的问题有关:How can I run integration tests after building all modules in a multi-module Maven project?
答案 0 :(得分:1)
为此使用构建服务器(Jenkins)怎么办?
如果您具有复杂的测试方案,则最好先构建(使用Maven),然后运行管道的另一步,将文件部署到正确的服务器/测试系统上并开始测试。