如何正确地实现Java模块与inter-module Maven构建测试依赖关系

我有一个多模块使用Maven和Java项目。 我现在想迁移到Java 9/10/11和实现模块(如JSR 376:Java平台模块系统)。 随着项目已经由Maven模块,和依赖直,为项目创建模块描述符很直接。

现在每个Maven模块有自己的模块描述符(module-info.java),在src/main/java文件夹中。 没有测试类的模块描述符。

然而,我偶然发现了我一直未能解决的问题,并没有找到任何描述如何解决:我怎么能有inter-module吗测试与Maven和Java模块依赖关系?

在我的例子中,我有一个“共同”Maven模块,它包含一些接口或抽象类(但没有具体实现)。 在相同的Maven模块,我有摘要测试,以确保适当的行为的实现这些接口/抽象类。 然后,有一个或多个子模块,接口实现/抽象类和扩展的抽象测试。

然而,当试图执行test阶段的Maven构建子模块将失败:

[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.8.0:testCompile (default-testCompile) on project my-impl-module: Compilation failure: Compilation failure:
[ERROR] C:\projects\com.example\my-module-test\my-impl-module\src\test\java\com\example\impl\FooImplTest.java:[4,25] error: cannot find symbol
[ERROR] symbol: class FooAbstractTest
[ERROR] location: package com.example.common
我怀疑这是因为测试不是模块的一部分。 即使Maven做一些“魔法”测试的范围内执行模块,它不会在我依赖的模块测试工作(由于某种原因)。 我怎么解决这个问题?

项目的结构是这样的:

├───my-common-module
│ ├───pom.xml
│ └───src
│ ├───main
│ │ └───java
│ │ ├───com
│ │ │ └───example
│ │ │ └───common
│ │ │ ├───AbstractFoo.java (abstract, implements Foo)
│ │ │ └───Foo.java (interface)
│ │ └───module-info.java (my.common.module: exports com.example.common)
│ └───test
│ └───java
│ └───com
│ └───example
│ └───common
│ └───FooAbstractTest.java (abstract class, tests Foo)
├───my-impl-module
│ ├───pom.xml
│ └───src
│ ├───main
│ │ └───java
│ │ ├───com
│ │ │ └───example
│ │ │ └───impl
│ │ │ └───FooImpl.java (extends AbstractFoo)
│ │ └───module-info.java (my.impl.module: requires my.common.module)
│ └───test
│ └───java
│ └───com
│ └───example
│ └───impl
│ └───FooImplTest.java (extends FooAbstractTest)
└───pom.xml
的依赖关系my-impl-module/pom.xml如下:

<dependencies>
<dependency>
<groupId>com.example</groupId>
<artifactId>my-common-module</artifactId>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>com.example</groupId>
<artifactId>my-common-module</artifactId>
<classifier>tests</classifier>
<scope>test</scope>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
注:以上是我创建的一个项目来证明这个问题。 我将试着更新完整项目的问题。 真正的项目是一个复杂多了在这里找到,但还没有模块化的主分支。

PS:代码本身没有什么错,一切使用正常的类路径(即编译并运行。 在IntelliJ)。 介绍了问题的模块。

猜你喜欢

转载自blog.51cto.com/14021402/2322239
今日推荐