mirror of https://github.com/apache/maven.git
Dependencies in two paths are not added to resolution when scope needs to be updated in the nearest due to any of nearest parents
PR: MNG-1895 git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@372053 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
6354dad32e
commit
24db0eb9c0
|
@ -201,14 +201,15 @@ public class DefaultArtifactCollector
|
||||||
if ( checkScopeUpdate( farthest, nearest, listeners ) )
|
if ( checkScopeUpdate( farthest, nearest, listeners ) )
|
||||||
{
|
{
|
||||||
fireEvent( ResolutionListener.UPDATE_SCOPE, listeners, nearest, farthest.getArtifact() );
|
fireEvent( ResolutionListener.UPDATE_SCOPE, listeners, nearest, farthest.getArtifact() );
|
||||||
|
/* we need nearest version but farthest scope */
|
||||||
// previously we cloned the artifact, but it is more effecient to just update the scope
|
nearest.disable();
|
||||||
// if problems are later discovered that the original object needs its original scope value, cloning may
|
farthest.getArtifact().setVersion( nearest.getArtifact().getVersion() );
|
||||||
// again be appropriate
|
}
|
||||||
nearest.getArtifact().setScope( farthest.getArtifact().getScope() );
|
else
|
||||||
|
{
|
||||||
|
farthest.disable();
|
||||||
}
|
}
|
||||||
fireEvent( ResolutionListener.OMIT_FOR_NEARER, listeners, farthest, nearest.getArtifact() );
|
fireEvent( ResolutionListener.OMIT_FOR_NEARER, listeners, farthest, nearest.getArtifact() );
|
||||||
farthest.disable();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -18,7 +18,6 @@ package org.apache.maven.artifact.resolver;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
|
@ -506,58 +505,104 @@ public class DefaultArtifactCollectorTest
|
||||||
assertEquals( "Check artifact list", createSet( new Object[]{a.artifact, b.artifact} ), res.getArtifacts() );
|
assertEquals( "Check artifact list", createSet( new Object[]{a.artifact, b.artifact} ), res.getArtifacts() );
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testCheckScopeUpdate()
|
public void testScopeUpdate( )
|
||||||
throws InvalidVersionSpecificationException, ArtifactResolutionException
|
throws InvalidVersionSpecificationException, ArtifactResolutionException
|
||||||
{
|
{
|
||||||
/* farthest = compile */
|
/* farthest = compile */
|
||||||
checkScopeUpdate( Artifact.SCOPE_COMPILE, Artifact.SCOPE_COMPILE, Artifact.SCOPE_COMPILE );
|
checkScopeUpdate( Artifact.SCOPE_COMPILE, Artifact.SCOPE_COMPILE, Artifact.SCOPE_COMPILE );
|
||||||
checkScopeUpdate( Artifact.SCOPE_COMPILE, Artifact.SCOPE_PROVIDED, Artifact.SCOPE_COMPILE );
|
checkScopeUpdate( Artifact.SCOPE_COMPILE, Artifact.SCOPE_PROVIDED, Artifact.SCOPE_COMPILE );
|
||||||
//checkScopeUpdate( Artifact.SCOPE_COMPILE, Artifact.SCOPE_RUNTIME, Artifact.SCOPE_COMPILE );
|
checkScopeUpdate( Artifact.SCOPE_COMPILE, Artifact.SCOPE_RUNTIME, Artifact.SCOPE_COMPILE );
|
||||||
checkScopeUpdate( Artifact.SCOPE_COMPILE, Artifact.SCOPE_SYSTEM, Artifact.SCOPE_COMPILE );
|
checkScopeUpdate( Artifact.SCOPE_COMPILE, Artifact.SCOPE_SYSTEM, Artifact.SCOPE_COMPILE );
|
||||||
//checkScopeUpdate( Artifact.SCOPE_COMPILE, Artifact.SCOPE_TEST, Artifact.SCOPE_COMPILE );
|
checkScopeUpdate( Artifact.SCOPE_COMPILE, Artifact.SCOPE_TEST, Artifact.SCOPE_COMPILE );
|
||||||
|
|
||||||
/* farthest = provided */
|
/* farthest = provided */
|
||||||
checkScopeUpdate( Artifact.SCOPE_PROVIDED, Artifact.SCOPE_COMPILE, Artifact.SCOPE_COMPILE );
|
checkScopeUpdate( Artifact.SCOPE_PROVIDED, Artifact.SCOPE_COMPILE, Artifact.SCOPE_COMPILE );
|
||||||
//checkScopeUpdate( Artifact.SCOPE_PROVIDED, Artifact.SCOPE_PROVIDED, Artifact.SCOPE_PROVIDED );
|
checkScopeUpdate( Artifact.SCOPE_PROVIDED, Artifact.SCOPE_PROVIDED, Artifact.SCOPE_PROVIDED );
|
||||||
checkScopeUpdate( Artifact.SCOPE_PROVIDED, Artifact.SCOPE_RUNTIME, Artifact.SCOPE_RUNTIME );
|
checkScopeUpdate( Artifact.SCOPE_PROVIDED, Artifact.SCOPE_RUNTIME, Artifact.SCOPE_RUNTIME );
|
||||||
//checkScopeUpdate( Artifact.SCOPE_PROVIDED, Artifact.SCOPE_SYSTEM, Artifact.SCOPE_SYSTEM );
|
checkScopeUpdate( Artifact.SCOPE_PROVIDED, Artifact.SCOPE_SYSTEM, Artifact.SCOPE_SYSTEM );
|
||||||
checkScopeUpdate( Artifact.SCOPE_PROVIDED, Artifact.SCOPE_TEST, Artifact.SCOPE_TEST );
|
checkScopeUpdate( Artifact.SCOPE_PROVIDED, Artifact.SCOPE_TEST, Artifact.SCOPE_TEST );
|
||||||
|
|
||||||
/* farthest = runtime */
|
/* farthest = runtime */
|
||||||
checkScopeUpdate( Artifact.SCOPE_RUNTIME, Artifact.SCOPE_COMPILE, Artifact.SCOPE_COMPILE );
|
checkScopeUpdate( Artifact.SCOPE_RUNTIME, Artifact.SCOPE_COMPILE, Artifact.SCOPE_COMPILE );
|
||||||
//checkScopeUpdate( Artifact.SCOPE_RUNTIME, Artifact.SCOPE_PROVIDED, Artifact.SCOPE_RUNTIME );
|
checkScopeUpdate( Artifact.SCOPE_RUNTIME, Artifact.SCOPE_PROVIDED, Artifact.SCOPE_RUNTIME );
|
||||||
checkScopeUpdate( Artifact.SCOPE_RUNTIME, Artifact.SCOPE_RUNTIME, Artifact.SCOPE_RUNTIME );
|
checkScopeUpdate( Artifact.SCOPE_RUNTIME, Artifact.SCOPE_RUNTIME, Artifact.SCOPE_RUNTIME );
|
||||||
//checkScopeUpdate( Artifact.SCOPE_RUNTIME, Artifact.SCOPE_SYSTEM, Artifact.SCOPE_SYSTEM );
|
checkScopeUpdate( Artifact.SCOPE_RUNTIME, Artifact.SCOPE_SYSTEM, Artifact.SCOPE_SYSTEM );
|
||||||
//checkScopeUpdate( Artifact.SCOPE_RUNTIME, Artifact.SCOPE_TEST, Artifact.SCOPE_RUNTIME );
|
checkScopeUpdate( Artifact.SCOPE_RUNTIME, Artifact.SCOPE_TEST, Artifact.SCOPE_RUNTIME );
|
||||||
|
|
||||||
/* farthest = system */
|
/* farthest = system */
|
||||||
checkScopeUpdate( Artifact.SCOPE_SYSTEM, Artifact.SCOPE_COMPILE, Artifact.SCOPE_COMPILE );
|
checkScopeUpdate( Artifact.SCOPE_SYSTEM, Artifact.SCOPE_COMPILE, Artifact.SCOPE_COMPILE );
|
||||||
//checkScopeUpdate( Artifact.SCOPE_SYSTEM, Artifact.SCOPE_PROVIDED, Artifact.SCOPE_PROVIDED );
|
checkScopeUpdate( Artifact.SCOPE_SYSTEM, Artifact.SCOPE_PROVIDED, Artifact.SCOPE_PROVIDED );
|
||||||
checkScopeUpdate( Artifact.SCOPE_SYSTEM, Artifact.SCOPE_RUNTIME, Artifact.SCOPE_RUNTIME );
|
checkScopeUpdate( Artifact.SCOPE_SYSTEM, Artifact.SCOPE_RUNTIME, Artifact.SCOPE_RUNTIME );
|
||||||
//checkScopeUpdate( Artifact.SCOPE_SYSTEM, Artifact.SCOPE_SYSTEM, Artifact.SCOPE_SYSTEM );
|
checkScopeUpdate( Artifact.SCOPE_SYSTEM, Artifact.SCOPE_SYSTEM, Artifact.SCOPE_SYSTEM );
|
||||||
checkScopeUpdate( Artifact.SCOPE_SYSTEM, Artifact.SCOPE_TEST, Artifact.SCOPE_TEST );
|
checkScopeUpdate( Artifact.SCOPE_SYSTEM, Artifact.SCOPE_TEST, Artifact.SCOPE_TEST );
|
||||||
|
|
||||||
/* farthest = test */
|
/* farthest = test */
|
||||||
checkScopeUpdate( Artifact.SCOPE_TEST, Artifact.SCOPE_COMPILE, Artifact.SCOPE_COMPILE );
|
checkScopeUpdate( Artifact.SCOPE_TEST, Artifact.SCOPE_COMPILE, Artifact.SCOPE_COMPILE );
|
||||||
//checkScopeUpdate( Artifact.SCOPE_TEST, Artifact.SCOPE_PROVIDED, Artifact.SCOPE_PROVIDED );
|
checkScopeUpdate( Artifact.SCOPE_TEST, Artifact.SCOPE_PROVIDED, Artifact.SCOPE_PROVIDED );
|
||||||
checkScopeUpdate( Artifact.SCOPE_TEST, Artifact.SCOPE_RUNTIME, Artifact.SCOPE_RUNTIME );
|
checkScopeUpdate( Artifact.SCOPE_TEST, Artifact.SCOPE_RUNTIME, Artifact.SCOPE_RUNTIME );
|
||||||
//checkScopeUpdate( Artifact.SCOPE_TEST, Artifact.SCOPE_SYSTEM, Artifact.SCOPE_SYSTEM );
|
checkScopeUpdate( Artifact.SCOPE_TEST, Artifact.SCOPE_SYSTEM, Artifact.SCOPE_SYSTEM );
|
||||||
checkScopeUpdate( Artifact.SCOPE_TEST, Artifact.SCOPE_TEST, Artifact.SCOPE_TEST );
|
checkScopeUpdate( Artifact.SCOPE_TEST, Artifact.SCOPE_TEST, Artifact.SCOPE_TEST );
|
||||||
}
|
}
|
||||||
|
|
||||||
private void checkScopeUpdate( String farthestScope, String nearestScope, String expectedScope )
|
private void checkScopeUpdate( String farthestScope, String nearestScope, String expectedScope )
|
||||||
throws ArtifactResolutionException, InvalidVersionSpecificationException
|
throws ArtifactResolutionException, InvalidVersionSpecificationException
|
||||||
|
{
|
||||||
|
checkScopeUpdateDirect( farthestScope, nearestScope, expectedScope );
|
||||||
|
checkScopeUpdateTransitively( farthestScope, nearestScope, expectedScope );
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkScopeUpdateTransitively( String farthestScope, String nearestScope, String expectedScope )
|
||||||
|
throws ArtifactResolutionException, InvalidVersionSpecificationException
|
||||||
{
|
{
|
||||||
ArtifactSpec a = createArtifact( "a", "1.0" );
|
ArtifactSpec a = createArtifact( "a", "1.0" );
|
||||||
ArtifactSpec b = createArtifact( "b", "1.0", nearestScope );
|
ArtifactSpec b = createArtifact( "b", "1.0", nearestScope );
|
||||||
ArtifactSpec c = createArtifact( "c", "1.0" );
|
ArtifactSpec c = createArtifact( "c", "1.0" );
|
||||||
a.addDependency( c );
|
a.addDependency( c );
|
||||||
ArtifactSpec d = createArtifact( "d", "2.0" );
|
ArtifactSpec dNearest = createArtifact( "d", "2.0" );
|
||||||
b.addDependency( d );
|
b.addDependency( dNearest );
|
||||||
c.addDependency( "d", "2.0", farthestScope );
|
ArtifactSpec dFarthest = createArtifact( "d", "2.0", farthestScope );
|
||||||
|
c.addDependency( dFarthest );
|
||||||
|
|
||||||
|
/* system and provided dependencies are not transitive */
|
||||||
|
if ( !Artifact.SCOPE_SYSTEM.equals( nearestScope ) && !Artifact.SCOPE_PROVIDED.equals( nearestScope ) )
|
||||||
|
{
|
||||||
|
checkScopeUpdate( a, b, expectedScope );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void checkScopeUpdateDirect( String farthestScope, String nearestScope, String expectedScope )
|
||||||
|
throws ArtifactResolutionException, InvalidVersionSpecificationException
|
||||||
|
{
|
||||||
|
ArtifactSpec a = createArtifact( "a", "1.0" );
|
||||||
|
ArtifactSpec b = createArtifact( "b", "1.0" );
|
||||||
|
ArtifactSpec c = createArtifact( "c", "1.0" );
|
||||||
|
a.addDependency( c );
|
||||||
|
ArtifactSpec dNearest = createArtifact( "d", "2.0", nearestScope );
|
||||||
|
b.addDependency( dNearest );
|
||||||
|
ArtifactSpec dFarthest = createArtifact( "d", "2.0", farthestScope );
|
||||||
|
c.addDependency( dFarthest );
|
||||||
|
|
||||||
|
checkScopeUpdate( a, b, expectedScope );
|
||||||
|
}
|
||||||
|
|
||||||
ArtifactResolutionResult res = collect( createSet( new Object[]{a.artifact, b.artifact} ),
|
private void checkScopeUpdate( ArtifactSpec a, ArtifactSpec b, String expectedScope )
|
||||||
new ScopeArtifactFilter( expectedScope ) );
|
throws ArtifactResolutionException, InvalidVersionSpecificationException
|
||||||
|
{
|
||||||
|
ScopeArtifactFilter filter;
|
||||||
|
if ( Artifact.SCOPE_PROVIDED.equals( expectedScope ) )
|
||||||
|
{
|
||||||
|
filter = new ScopeArtifactFilter( Artifact.SCOPE_COMPILE );
|
||||||
|
}
|
||||||
|
else if ( Artifact.SCOPE_SYSTEM.equals( expectedScope ) )
|
||||||
|
{
|
||||||
|
filter = new ScopeArtifactFilter( Artifact.SCOPE_COMPILE );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
filter = new ScopeArtifactFilter( expectedScope );
|
||||||
|
}
|
||||||
|
|
||||||
|
ArtifactResolutionResult res = collect( createSet( new Object[] { a.artifact, b.artifact } ), filter );
|
||||||
Artifact artifact = getArtifact( "d", res.getArtifacts() );
|
Artifact artifact = getArtifact( "d", res.getArtifacts() );
|
||||||
assertNotNull( "MNG-1895 Dependency was not added to resolution", artifact );
|
assertNotNull( "MNG-1895 Dependency was not added to resolution", artifact );
|
||||||
assertEquals( "Check scope", expectedScope, artifact.getScope() );
|
assertEquals( "Check scope", expectedScope, artifact.getScope() );
|
||||||
|
@ -776,8 +821,9 @@ public class DefaultArtifactCollectorTest
|
||||||
versionRange = VersionRange.createFromVersionSpec( d.getVersion() );
|
versionRange = VersionRange.createFromVersionSpec( d.getVersion() );
|
||||||
}
|
}
|
||||||
Artifact artifact;
|
Artifact artifact;
|
||||||
if ( d.getScope().equals( Artifact.SCOPE_TEST ) )
|
if ( d.getScope().equals( Artifact.SCOPE_TEST ) || d.getScope().equals( Artifact.SCOPE_PROVIDED ) )
|
||||||
{
|
{
|
||||||
|
/* don't call createDependencyArtifact as it'll ignore test and provided scopes */
|
||||||
artifact = artifactFactory.createArtifact( d.getGroupId(), d.getArtifactId(), d.getVersion(), d
|
artifact = artifactFactory.createArtifact( d.getGroupId(), d.getArtifactId(), d.getVersion(), d
|
||||||
.getScope(), d.getType() );
|
.getScope(), d.getType() );
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue