Der Scope sollte in der dependencyManagement-Sektion der pom.xml nicht angegeben werden, außer in bestimmten Ausnahmefällen.
Was ist die Funktion von dependencyManagement?
Die dependencyManagement-Sektion dient dazu, Abhängigkeiten zentral zu verwalten, insbesondere in Multi-Modul-Projekten. Sie ermöglicht:
– Die zentrale Definition von Versionsnummern und anderen Attributen (z. B. Exclusions) für Abhängigkeiten.
– Die Vererbung dieser Informationen durch untergeordnete Module, ohne dass diese die Versionen explizit angeben müssen.
Abhängigkeiten, die in dependencyManagement definiert sind, werden nicht automatisch Teil des Projekts. Sie müssen explizit in der dependencyManagement-Sektion eines Moduls referenziert werden, um tatsächlich verwendet zu werden.
Sollte Scope in dependencyManagement angegeben werden?
In der Regel sollte der Scope nicht in dependencyManagement angegeben werden. Der Grund dafür ist, dass der Scope hauptsächlich den Kontext definiert, in dem eine Abhängigkeit verwendet wird (z. B. compile, test, runtime), und dies spezifisch für die tatsächliche Verwendung im Modul festgelegt werden sollte. Der Scope gehört daher primär in die dependencies-Sektion.
Ausnahme: Scope import
Der einzige Scope, der sinnvoll in <dependencyManagement verwendet wird, ist import. Dieser wird genutzt, um eine BOM (Bill of Materials) zu importieren, die wiederum andere Abhängigkeiten und deren Versionen definiert. Beispiel:
1 2 3 4 5 6 7 8 9 10 11 |
<dependencyManagement> <dependencies> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-framework-bom</artifactId> <version>5.3.10</version> <scope>import</scope> <type>pom</type> </dependency> </dependencies> </dependencyManagement> |
Dieser Scope ist speziell für die Verwaltung großer Projekte mit mehreren Abhängigkeiten gedacht.
Best Practices
1. Definiere den Scope in dependencies : Wenn eine Abhängigkeit tatsächlich verwendet wird, sollte ihr Scope im entsprechenden Modul spezifiziert werden.
1 2 3 4 5 6 7 8 |
<dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.13.2</version> <scope>test</scope> </dependency> </dependencies> |
2. Vermeide Scope-Deklarationen in dependencyManagement , außer bei import.
3. Nutze dependencyManagement für zentrale Versionierung : Definiere dort nur die Versionen und Attribute, die für alle Module gelten sollen.
Also der Scope sollte im Allgemeinen nicht in der dependencyManagement-Sektion angegeben werden, da dies gegen die Best Practices verstößt und potenziell zu Verwirrung führt. Die Ausnahme bildet der Scope import, der speziell für BOMs gedacht ist.