Skip to content

[MNG-5971] Imported dependencies should be available to inheritance processing #7729

@jira-importer

Description

@jira-importer

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:

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

Metadata

Metadata

Assignees

No one assigned

    Labels

    bugSomething isn't workingpriority:trivialCosmetic problem like misspelled words or misaligned text

    Type

    No type

    Projects

    No projects

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions