在 Maven BOM(物料清单)中定义依赖范围是好的做法吗?

Is it good practice to define scope of dependencies in Maven BOM (bill of materials)?

我有一个像这样的 pom.xml 用作 BOM(物料清单)。定义的依赖项之一是 *-test 工件,用于测试使用此 BOM 中的库的代码。

问题是:指定 *-test 工件仅用于 BOM 本身的 test 范围是否合适/良好做法,还是应该留给 BOM 的用户使用如果需要,在他们项目的 POM 中指定?

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.example.mylib</groupId>
    <artifactId>mylib-bom</artifactId>
    <version>1.0.0-SNAPSHOT</version>
    <packaging>pom</packaging>
    <name>MyLib (Bill of Materials)</name>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>com.example.mylib</groupId>
                <artifactId>mylib-cool-library</artifactId>
                <version>${project.version}</version>
            </dependency>    
            <dependency>
                <groupId>com.example.mylib</groupId>
                <artifactId>mylib-test</artifactId>
                <version>${project.version}</version>
                <scope>test</scope> <!-- === HERE === -->
            </dependency>    
        </dependencies>
    </dependencyManagement>    
</project>

我正在研究现有项目是如何做到这一点的,例如,Spring Framework BOM 确实没有明确定义任何范围。但我仍然想知道是否有一些不成文的规定?

最佳做法是让用户决定范围,不要在 BOM(或父 pom)中设置它。

当您在 BOM 中设置范围(设置为 compile 以外的任何范围)时,您会更改该依赖项的默认范围,如用户项目中所见。 maven 中的默认依赖范围是 compile,所以当你希望它被编译时,通常的做法是省略依赖范围。如果 BOM 强加了另一个范围,对于使用 BOM 的其他开发人员(或者甚至是您以后的某个时间点)来说,这可能是一个令人讨厌的惊喜。