-
Notifications
You must be signed in to change notification settings - Fork 2.8k
Description
Stephane Nicoll opened MNG-5971 and commented
When a project extends from a parent with a dependencyManagement
section, it is not always possible to properly override (and align) the version to use for a group of dependencies.
We typically use Bill Of Materials to gather a group of modules and make sure their versions are consistent.
The following project demonstrates the issue: https://github.com/snicoll-scratches/maven-dependency-management
The first commit is a working use case where the parent uses a bom with version A and we use the same bom with version B in the child. Version B is used as expected.
The second commit demonstrates the faulty scenario. Rather than using a bom in the parent, we use a direct dependency (provided by that bom). We still use the bom with a different version. In that case all the dependencies but the one provided by the parent are overridden (leading to mixed versions for the dependencies provided by the BOM).
It looks like the distance is still used to compute the version while the graph of dependencies should be flatten at each step for a proper override.
Thoughts? Thanks!
Affects: 3.3.3
Attachments:
- bom-cloud.zip (50.23 kB)
Issue Links:
-
MNG-5547 import scope of dependencyManagement doesn't seem to work
("is duplicated by") -
MNG-5947 dependencyManagement import section does not resolve dependencies using "nearest" definition
("is duplicated by") -
MNG-6246 Inconsistent override behaivor with BOM vs dependency
("is duplicated by") -
MNG-6161 Dependencies' management via <scope>import</scope> should take precedence over inherited definitions
("is duplicated by") -
MNG-5947 dependencyManagement import section does not resolve dependencies using "nearest" definition
-
MNG-5982 The POM for ... is invalid, transitive dependencies ... while property was overriden
-
MNG-7852 Use all the versions for dependency resolution rather than "nearest first" or "declared first"
-
MNG-6079 3.4 regression: cannot override version of a dependencyManagement in a submodule any more
("supercedes")
Remote Links:
6 votes, 20 watchers