[MSHADE-573] Fix missing exclusions - direct and transitive #770
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Following this checklist to help us incorporate your
contribution quickly and easily:
for the change (usually before you start working on it). Trivial changes like typos do not
require a JIRA issue. Your pull request should address just this issue, without
pulling in other changes. =[MSHADE-202] When promoteTransitiveDependencies=true, some <exclusions> are stripped from the dependency-reduced-pom #573
[MSHADE-XXX] - Fixes bug in ApproximateQuantiles,where you replace
MSHADE-XXXwith the appropriate JIRA issue. Best practiceis to use the JIRA issue title in the pull request title and in the first line of the
commit message.
mvn clean verifyto make sure basic checks pass. A more thorough check willbe performed on your pull request automatically.
mvn -Prun-its clean verify).If your pull request is about ~20 lines of code you don't need to sign an
Individual Contributor License Agreement if you are unsure
please ask on the developers list.
To make clear that you license your contribution under
the Apache License Version 2.0, January 2004
you have to acknowledge this by using the following check-box.
I hereby declare this contribution to be licenced under the Apache License Version 2.0, January 2004
In any other case, please file an Apache Individual Contributor License Agreement.
Pull Request Description
Preserve original and transitive exclusions in dependency-reduced-pom to improve POM correctness
Summary
This PR fixes a long-standing issue where exclusions declared in the original
pom.xml— including wildcard and transitive exclusions — were not propagated to the generateddependency-reduced-pom.xml. As a result, the reduced POM could reintroduce dependencies that the user had explicitly excluded.The change introduces a dedicated exclusion resolution step and updates the reduced-POM generation so that:
Motivation and context
Example of the incorrect behavior (existing upstream case):
dependency-reduced-pom.xmlpreviously dropped the exclusions entirely:Reference:
maven-shade-plugin/src/it/projects/MSHADE-467_parallel-dependency-reduced-pom/pom.xml
Line 64 in 073e7ca
With this PR, exclusions like the above (including
*/*) are preserved in the reduced POM.What changed
DependenciesExclusionResolverto compute effective exclusions for both direct and transitive dependencies.DependencyListutility to help build the reduced POM dependency set with proper scopes and exclusions.ShadeMojoto apply resolved exclusions during reduced POM generation and to streamline transitive dependency handling.dep-reduced-pom-with-transitive-dependencies-with-exclusions(verifies propagation of direct and transitive exclusions).shadeMT1..shadeMT4/expected-dependency-reduced-pom.xml).Behavior before vs after
dependency-reduced-pom.xmlcould omit user-declared exclusions and omit required transitive exclusions, causing unexpected dependencies to appear for consumers.Why this matters
Testing
src/it/projects/dep-reduced-pom-with-transitive-dependencies-with-exclusions/*expected-dependency-reduced-pom.xmlsnapshots for visibility into changes, for example:src/it/projects/MSHADE-467_parallel-dependency-reduced-pom/shadeMT1/expected-dependency-reduced-pom.xmlNote: At this stage only the foundational tests are included. If the overall approach is accepted, I will add more test coverage, including corner cases (wildcards, multiple excludes, ordering, and mixed scopes).
Open question: how strict should IT verification be?
Currently, to make differences obvious, I added snapshot files like:
src/it/projects/MSHADE-467_parallel-dependency-reduced-pom/shadeMT1/expected-dependency-reduced-pom.xmlIs a strict one-to-one comparison (expected vs. generated reduced POM) desirable for ITs? My recommendation:
dependencyandexclusionlists where ordering is non-semantic, and compare normalized XML.I’m happy to implement whichever verification approach the project prefers.