mirror of https://github.com/apache/maven.git
Adding the notion of a build-context, and several build-context classes that can be used: ProjectBuildContext, which contains lineage and current-project info, ExecutionBuildContext, which contains the information in the original MavenExecutionRequest, and SystemBuildContext, which contains things like System properties...these use the BuildContextManager to store and retrieve their info from the core container's Context object.
git-svn-id: https://svn.apache.org/repos/asf/maven/components/trunk@497911 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
6c2268f0bd
commit
dfc4a10c68
|
@ -0,0 +1,25 @@
|
|||
<?xml version="1.0"?><project>
|
||||
<modelVersion>4.0.0</modelVersion>
|
||||
|
||||
<parent>
|
||||
<artifactId>maven</artifactId>
|
||||
<groupId>org.apache.maven</groupId>
|
||||
<version>2.1-SNAPSHOT</version>
|
||||
</parent>
|
||||
|
||||
<artifactId>maven-build-context</artifactId>
|
||||
<name>Maven Build Context</name>
|
||||
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>org.codehaus.plexus</groupId>
|
||||
<artifactId>plexus-container-default</artifactId>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>junit</groupId>
|
||||
<artifactId>junit</artifactId>
|
||||
<version>3.8.1</version>
|
||||
<scope>test</scope>
|
||||
</dependency>
|
||||
</dependencies>
|
||||
</project>
|
|
@ -0,0 +1,34 @@
|
|||
package org.apache.maven.context;
|
||||
|
||||
/**
|
||||
* Basic data bus for Maven builds, through which the various subsystems can communicate with one
|
||||
* another without causing bloat in the APIs.
|
||||
*
|
||||
* @author jdcasey
|
||||
*
|
||||
*/
|
||||
public interface BuildContext
|
||||
{
|
||||
|
||||
/**
|
||||
* Add a new piece of data to the build context.
|
||||
*/
|
||||
void put( Object key, Object value );
|
||||
|
||||
/**
|
||||
* Retrieve something previously stored in the build context, or null if the key doesn't exist.
|
||||
*/
|
||||
Object get( Object key );
|
||||
|
||||
/**
|
||||
* Remove a mapped data element from the build context, returning the Object removed, if any.
|
||||
*/
|
||||
Object delete( Object key );
|
||||
|
||||
/**
|
||||
* Add a new piece of managed build data to the build context. Managed data elements supply their
|
||||
* own storage key.
|
||||
*/
|
||||
void put( ManagedBuildData managedData );
|
||||
|
||||
}
|
|
@ -0,0 +1,34 @@
|
|||
package org.apache.maven.context;
|
||||
|
||||
/**
|
||||
* Manager interface used to store, read, and clear the BuildContext out of the container.
|
||||
*
|
||||
* @author jdcasey
|
||||
*/
|
||||
public interface BuildContextManager
|
||||
{
|
||||
|
||||
String ROLE = BuildContextManager.class.getName();
|
||||
|
||||
/**
|
||||
* Create a new instance of BuildContext
|
||||
*/
|
||||
BuildContext newUnstoredInstance();
|
||||
|
||||
/**
|
||||
* Read the BuildContext from the container. If it doesn't already exist, optionally create it.
|
||||
*/
|
||||
BuildContext readBuildContext( boolean create );
|
||||
|
||||
/**
|
||||
* Store the BuildContext in the container context.
|
||||
*/
|
||||
void storeBuildContext( BuildContext context );
|
||||
|
||||
/**
|
||||
* Clear the contents of the BuildContext, both in the current instance, and in the container
|
||||
* context.
|
||||
*/
|
||||
void clearBuildContext();
|
||||
|
||||
}
|
|
@ -0,0 +1,85 @@
|
|||
package org.apache.maven.context;
|
||||
|
||||
import java.util.LinkedHashMap;
|
||||
import java.util.Map;
|
||||
|
||||
/**
|
||||
* Default implementation of BuildContext, for use with the DefaultBuildContextManager. This
|
||||
* implementation uses a Map for its backing store, and if constructed with no parameters, will use
|
||||
* a LinkedHashMap.
|
||||
*
|
||||
* @author jdcasey
|
||||
*
|
||||
*/
|
||||
public class DefaultBuildContext
|
||||
implements BuildContext
|
||||
{
|
||||
|
||||
private final Map contextMap;
|
||||
|
||||
/**
|
||||
* Construct a new build context, using the supplied map as the backing store. NOTE: The
|
||||
* supplied map will be copied.
|
||||
*/
|
||||
public DefaultBuildContext( Map contextMap )
|
||||
{
|
||||
if ( contextMap == null )
|
||||
{
|
||||
throw new NullPointerException( "DefaultBuildContext requires a non-null contextMap parameter, or no parameter at all." );
|
||||
}
|
||||
|
||||
this.contextMap = contextMap;
|
||||
}
|
||||
|
||||
/**
|
||||
* Construct a new build context, using a new instance of LinkedHashMap.
|
||||
*/
|
||||
public DefaultBuildContext()
|
||||
{
|
||||
this.contextMap = new LinkedHashMap();
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the object mapped to 'key' from the build context. If there was such a mapping, return
|
||||
* the value mapped to the key.
|
||||
*/
|
||||
public Object delete( Object key )
|
||||
{
|
||||
return contextMap.remove( key );
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieve the object mapped to 'key', or null if the mapping doesn't exist. Mapping 'key' to
|
||||
* null should also be possible, but will be indistinguishable from a missing mapping.
|
||||
*/
|
||||
public Object get( Object key )
|
||||
{
|
||||
return contextMap.get( key );
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a new data mapping to the build context.
|
||||
*/
|
||||
public void put( Object key, Object value )
|
||||
{
|
||||
contextMap.put( key, value );
|
||||
}
|
||||
|
||||
/**
|
||||
* Return the Map used to store data elements, for storage by the DefaultBuildContextManager.
|
||||
*/
|
||||
Object getContextMap()
|
||||
{
|
||||
return contextMap;
|
||||
}
|
||||
|
||||
/**
|
||||
* Add a new piece of managed data to the build context, using the key supplied by
|
||||
* managedData.getStorageKey().
|
||||
*/
|
||||
public void put( ManagedBuildData managedData )
|
||||
{
|
||||
contextMap.put( managedData.getStorageKey(), managedData );
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,121 @@
|
|||
package org.apache.maven.context;
|
||||
|
||||
import org.codehaus.plexus.context.Context;
|
||||
import org.codehaus.plexus.context.ContextException;
|
||||
import org.codehaus.plexus.personality.plexus.lifecycle.phase.Contextualizable;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
/**
|
||||
* Default implementation of the BuildContextManager, which handles instances of DefaultBuildContext.
|
||||
*
|
||||
* @plexus.component role="org.apache.maven.context.BuildContextManager" role-hint="default"
|
||||
* @author jdcasey
|
||||
*/
|
||||
public class DefaultBuildContextManager
|
||||
implements BuildContextManager, Contextualizable
|
||||
{
|
||||
public static final String ROLE_HINT = "default";
|
||||
|
||||
protected static final String BUILD_CONTEXT_MAP_KEY = "org.apache.maven.context:DefaultBuildContextManager:contextMap";
|
||||
|
||||
private Context context;
|
||||
|
||||
/**
|
||||
* Create a new instance of DefaultBuildContext, and return it. Each method call creates a brand
|
||||
* new instance.
|
||||
*/
|
||||
public BuildContext newUnstoredInstance()
|
||||
{
|
||||
return new DefaultBuildContext();
|
||||
}
|
||||
|
||||
/**
|
||||
* Clear the contents of the build context inside the container context.
|
||||
*/
|
||||
public void clearBuildContext()
|
||||
{
|
||||
clearContextContainerMap();
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieve the current BuildContext out of the container context.
|
||||
*
|
||||
* @param create Whether to create the BuildContext if it doesn't exist in the container
|
||||
*/
|
||||
public BuildContext readBuildContext( boolean create )
|
||||
{
|
||||
Map contextMap = getContextContainerMap( create );
|
||||
|
||||
if ( !create && contextMap == null )
|
||||
{
|
||||
return null;
|
||||
}
|
||||
else
|
||||
{
|
||||
return new DefaultBuildContext( contextMap );
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Store the given BuildContext inside the container.
|
||||
*/
|
||||
public void storeBuildContext( BuildContext context )
|
||||
{
|
||||
if ( context instanceof DefaultBuildContext )
|
||||
{
|
||||
this.context.put( BUILD_CONTEXT_MAP_KEY, ((DefaultBuildContext)context).getContextMap() );
|
||||
}
|
||||
else
|
||||
{
|
||||
throw new IllegalArgumentException( this.getClass().getName() + " does not know how to store a context of type: " + context.getClass().getName() );
|
||||
}
|
||||
}
|
||||
|
||||
protected Map getContextContainerMap( boolean create )
|
||||
{
|
||||
Map containerMap = null;
|
||||
|
||||
if ( context.contains( BUILD_CONTEXT_MAP_KEY ) )
|
||||
{
|
||||
try
|
||||
{
|
||||
containerMap = (Map) context.get( BUILD_CONTEXT_MAP_KEY );
|
||||
}
|
||||
catch ( ContextException e )
|
||||
{
|
||||
throw new IllegalStateException( "Failed to retrieve BuildAdvisor "
|
||||
+ "serialization map from context, though the context claims it exists. Error: "
|
||||
+ e.getMessage() );
|
||||
}
|
||||
}
|
||||
else if ( create )
|
||||
{
|
||||
containerMap = new HashMap();
|
||||
context.put( BUILD_CONTEXT_MAP_KEY, containerMap );
|
||||
}
|
||||
|
||||
return containerMap;
|
||||
}
|
||||
|
||||
protected void clearContextContainerMap()
|
||||
{
|
||||
Map containerMap = getContextContainerMap( false );
|
||||
|
||||
if ( containerMap != null )
|
||||
{
|
||||
containerMap.clear();
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Retrieve the container context for storing the BuildContext data.
|
||||
*/
|
||||
public void contextualize( Context context )
|
||||
throws ContextException
|
||||
{
|
||||
this.context = context;
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,21 @@
|
|||
package org.apache.maven.context;
|
||||
|
||||
/**
|
||||
* Management interface for things that are meant to be stored/retrieved from the Maven BuildContext
|
||||
* natively. Such things need to give the BuildContextManager a key for mapping it into the context.
|
||||
*
|
||||
* @author jdcasey
|
||||
*
|
||||
*/
|
||||
public interface ManagedBuildData
|
||||
{
|
||||
|
||||
/**
|
||||
* Retrieve the context key under which this instance of managed data should be stored in the
|
||||
* BuildContext instance.
|
||||
*
|
||||
* @return The BuildContext mapping key.
|
||||
*/
|
||||
String getStorageKey();
|
||||
|
||||
}
|
|
@ -0,0 +1,76 @@
|
|||
package org.apache.maven.context;
|
||||
|
||||
import java.util.Properties;
|
||||
|
||||
public class SystemBuildContext
|
||||
implements ManagedBuildData
|
||||
{
|
||||
|
||||
public static final String BUILD_CONTEXT_KEY = SystemBuildContext.class.getName();
|
||||
|
||||
private Properties systemProperties;
|
||||
private Properties envars;
|
||||
|
||||
public SystemBuildContext()
|
||||
{
|
||||
this.systemProperties = System.getProperties();
|
||||
}
|
||||
|
||||
public void setEnvironmentVariables( Properties envars )
|
||||
{
|
||||
this.envars = envars;
|
||||
}
|
||||
|
||||
public Properties getEnvironmentVariables()
|
||||
{
|
||||
return envars;
|
||||
}
|
||||
|
||||
public void setSystemProperties( Properties systemProperties )
|
||||
{
|
||||
this.systemProperties = systemProperties;
|
||||
}
|
||||
|
||||
public Properties getSystemProperties()
|
||||
{
|
||||
return systemProperties;
|
||||
}
|
||||
|
||||
public String getSystemProperty( String name )
|
||||
{
|
||||
return systemProperties == null ? null : systemProperties.getProperty( name );
|
||||
}
|
||||
|
||||
public String getStorageKey()
|
||||
{
|
||||
return BUILD_CONTEXT_KEY;
|
||||
}
|
||||
|
||||
public static SystemBuildContext getSystemBuildContext( BuildContextManager buildContextManager, boolean create )
|
||||
{
|
||||
BuildContext buildContext = buildContextManager.readBuildContext( false );
|
||||
|
||||
SystemBuildContext systemContext = null;
|
||||
|
||||
if ( buildContext != null )
|
||||
{
|
||||
systemContext = (SystemBuildContext) buildContext.get( BUILD_CONTEXT_KEY );
|
||||
}
|
||||
|
||||
if ( create && systemContext == null )
|
||||
{
|
||||
systemContext = new SystemBuildContext();
|
||||
}
|
||||
|
||||
return systemContext;
|
||||
}
|
||||
|
||||
public void store( BuildContextManager buildContextManager )
|
||||
{
|
||||
BuildContext buildContext = buildContextManager.readBuildContext( true );
|
||||
|
||||
buildContext.put( this );
|
||||
|
||||
buildContextManager.storeBuildContext( buildContext );
|
||||
}
|
||||
}
|
|
@ -0,0 +1,9 @@
|
|||
<component-set>
|
||||
<components>
|
||||
<component>
|
||||
<role>org.apache.maven.context.BuildContextManager</role>
|
||||
<role-hint>default</role-hint>
|
||||
<implementation>org.apache.maven.context.DefaultBuildContextManager</implementation>
|
||||
</component>
|
||||
</components>
|
||||
</component-set>
|
|
@ -0,0 +1,93 @@
|
|||
package org.apache.maven.context;
|
||||
|
||||
import org.codehaus.plexus.PlexusTestCase;
|
||||
|
||||
public abstract class AbstractBuildContextManagerTest
|
||||
extends PlexusTestCase
|
||||
{
|
||||
private BuildContextManager mgr;
|
||||
|
||||
protected abstract String getRoleHintBeforeSetUp();
|
||||
|
||||
protected BuildContextManager getBuildContextManager()
|
||||
{
|
||||
return mgr;
|
||||
}
|
||||
|
||||
public void setUp() throws Exception
|
||||
{
|
||||
super.setUp();
|
||||
|
||||
mgr = (BuildContextManager) lookup( BuildContextManager.ROLE, getRoleHintBeforeSetUp() );
|
||||
}
|
||||
|
||||
public void testNewUnstoredInstance_ShouldReturnValidContextInstance()
|
||||
{
|
||||
BuildContext context = mgr.newUnstoredInstance();
|
||||
|
||||
assertNotNull( context );
|
||||
|
||||
String key = "key";
|
||||
String value = "value";
|
||||
|
||||
context.put( key, value );
|
||||
|
||||
assertEquals( value, context.get( key ) );
|
||||
|
||||
context.delete( key );
|
||||
|
||||
assertNull( context.get( key ) );
|
||||
}
|
||||
|
||||
public void testNewUnstoredInstance_SuccessiveCallsShouldReturnDistinctContextInstances()
|
||||
{
|
||||
BuildContext context = mgr.newUnstoredInstance();
|
||||
BuildContext context2 = mgr.newUnstoredInstance();
|
||||
|
||||
assertNotNull( context );
|
||||
assertNotNull( context2 );
|
||||
assertNotSame( context, context2 );
|
||||
}
|
||||
|
||||
public void testStoreAndRead_ShouldRetrieveStoredValueAfterRead()
|
||||
{
|
||||
BuildContext ctx = mgr.newUnstoredInstance();
|
||||
|
||||
String key = "key";
|
||||
String value = "value";
|
||||
|
||||
ctx.put( key, value );
|
||||
|
||||
mgr.storeBuildContext( ctx );
|
||||
|
||||
BuildContext ctx2 = mgr.readBuildContext( false );
|
||||
|
||||
assertNotNull( ctx2 );
|
||||
assertEquals( value, ctx2.get( key ) );
|
||||
}
|
||||
|
||||
public void testStoreAndClear_ShouldNotRetrieveStoredValueAfterClear()
|
||||
{
|
||||
BuildContext ctx = mgr.newUnstoredInstance();
|
||||
|
||||
String key = "key";
|
||||
String value = "value";
|
||||
|
||||
ctx.put( key, value );
|
||||
|
||||
mgr.storeBuildContext( ctx );
|
||||
|
||||
// verify that we can get the value back out.
|
||||
BuildContext ctx2 = mgr.readBuildContext( false );
|
||||
|
||||
assertNotNull( ctx2 );
|
||||
assertEquals( value, ctx2.get( key ) );
|
||||
|
||||
mgr.clearBuildContext();
|
||||
|
||||
BuildContext ctx3 = mgr.readBuildContext( false );
|
||||
|
||||
assertNull( ctx3.get( key ) );
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,61 @@
|
|||
package org.apache.maven.context;
|
||||
|
||||
import java.util.HashMap;
|
||||
import java.util.Map;
|
||||
|
||||
import junit.framework.TestCase;
|
||||
|
||||
public abstract class AbstractBuildContextTest
|
||||
extends TestCase
|
||||
{
|
||||
|
||||
protected abstract BuildContext newContext();
|
||||
|
||||
public void testPutAndGet_ShouldStoreAndRetrieveKeyValuePairOfStrings()
|
||||
{
|
||||
BuildContext ctx = newContext();
|
||||
|
||||
String key = "key";
|
||||
String value = "value";
|
||||
|
||||
ctx.put( key, value );
|
||||
|
||||
assertEquals( value, ctx.get( key ) );
|
||||
}
|
||||
|
||||
public void testPutAndGet_ShouldStoreAndRetrieveStringKeyWithMapValue()
|
||||
{
|
||||
BuildContext ctx = newContext();
|
||||
|
||||
String key = "key";
|
||||
Map value = new HashMap();
|
||||
|
||||
String key2 = "key2";
|
||||
String value2 = "value";
|
||||
|
||||
value.put( key2, value2 );
|
||||
|
||||
ctx.put( key, value );
|
||||
|
||||
assertSame( value, ctx.get( key ) );
|
||||
|
||||
assertEquals( value2, ((Map) ctx.get( key )).get( key2 ) );
|
||||
}
|
||||
|
||||
public void testPutDeleteAndGet_ShouldStoreKeyValuePairDeleteThemAndRetrieveNull()
|
||||
{
|
||||
BuildContext ctx = newContext();
|
||||
|
||||
String key = "key";
|
||||
String value = "value";
|
||||
|
||||
ctx.put( key, value );
|
||||
|
||||
assertEquals( value, ctx.get( key ) );
|
||||
|
||||
ctx.delete( key );
|
||||
|
||||
assertNull( ctx.get( key ) );
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,12 @@
|
|||
package org.apache.maven.context;
|
||||
|
||||
public class DefaultBuildContextManagerTest
|
||||
extends AbstractBuildContextManagerTest
|
||||
{
|
||||
|
||||
protected String getRoleHintBeforeSetUp()
|
||||
{
|
||||
return DefaultBuildContextManager.ROLE_HINT;
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,40 @@
|
|||
package org.apache.maven.context;
|
||||
|
||||
import java.util.Collections;
|
||||
import java.util.Map;
|
||||
|
||||
public class DefaultBuildContextTest
|
||||
extends AbstractBuildContextTest
|
||||
{
|
||||
|
||||
protected BuildContext newContext()
|
||||
{
|
||||
return new DefaultBuildContext();
|
||||
}
|
||||
|
||||
public void testConstructor_ShouldThrowNPEWhenContextMapParameterIsNull()
|
||||
{
|
||||
try
|
||||
{
|
||||
new DefaultBuildContext( null );
|
||||
|
||||
fail( "Should throw NPE when contextMap parameter is null." );
|
||||
}
|
||||
catch( NullPointerException e )
|
||||
{
|
||||
// should happen.
|
||||
}
|
||||
}
|
||||
|
||||
public void testConstructor_ShouldRetrieveValueFromPreExistingContextMap()
|
||||
{
|
||||
String key = "key";
|
||||
String value = "value";
|
||||
|
||||
Map contextMap = Collections.singletonMap( key, value );
|
||||
BuildContext ctx = new DefaultBuildContext( contextMap );
|
||||
|
||||
assertEquals( value, ctx.get( key ) );
|
||||
}
|
||||
|
||||
}
|
|
@ -27,6 +27,11 @@
|
|||
<artifactId>maven-core</artifactId>
|
||||
<name>Maven Core</name>
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>org.apache.maven</groupId>
|
||||
<artifactId>maven-build-context</artifactId>
|
||||
<version>2.1-SNAPSHOT</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.apache.maven</groupId>
|
||||
<artifactId>maven-settings</artifactId>
|
||||
|
|
|
@ -20,8 +20,11 @@ package org.apache.maven;
|
|||
import org.apache.maven.artifact.repository.ArtifactRepository;
|
||||
import org.apache.maven.artifact.resolver.ArtifactResolutionException;
|
||||
import org.apache.maven.artifact.versioning.DefaultArtifactVersion;
|
||||
import org.apache.maven.context.BuildContextManager;
|
||||
import org.apache.maven.context.SystemBuildContext;
|
||||
import org.apache.maven.execution.BuildFailure;
|
||||
import org.apache.maven.execution.DefaultMavenExecutionResult;
|
||||
import org.apache.maven.execution.ExecutionBuildContext;
|
||||
import org.apache.maven.execution.MavenExecutionRequest;
|
||||
import org.apache.maven.execution.MavenExecutionResult;
|
||||
import org.apache.maven.execution.MavenSession;
|
||||
|
@ -74,6 +77,8 @@ public class DefaultMaven
|
|||
// Components
|
||||
// ----------------------------------------------------------------------
|
||||
|
||||
protected BuildContextManager buildContextManager;
|
||||
|
||||
protected MavenProjectBuilder projectBuilder;
|
||||
|
||||
protected LifecycleExecutor lifecycleExecutor;
|
||||
|
@ -98,6 +103,8 @@ public class DefaultMaven
|
|||
{
|
||||
request.setStartTime( new Date() );
|
||||
|
||||
initializeBuildContext( request );
|
||||
|
||||
EventDispatcher dispatcher = new DefaultEventDispatcher( request.getEventMonitors() );
|
||||
|
||||
String event = MavenEvents.REACTOR_EXECUTION;
|
||||
|
@ -166,6 +173,21 @@ public class DefaultMaven
|
|||
return new DefaultMavenExecutionResult( result.getReactorManager() );
|
||||
}
|
||||
|
||||
/**
|
||||
* Initialize some context objects to be stored in the container's context map for reference by
|
||||
* other Maven components (including custom components that need more information about the
|
||||
* build than is supplied to them by the APIs).
|
||||
*/
|
||||
private void initializeBuildContext( MavenExecutionRequest request )
|
||||
{
|
||||
new ExecutionBuildContext( request ).store( buildContextManager );
|
||||
|
||||
SystemBuildContext systemContext = SystemBuildContext.getSystemBuildContext( buildContextManager, true );
|
||||
|
||||
systemContext.setSystemProperties( request.getProperties() );
|
||||
systemContext.store( buildContextManager );
|
||||
}
|
||||
|
||||
private void logErrors( ReactorManager rm,
|
||||
boolean showErrors )
|
||||
{
|
||||
|
@ -304,17 +326,22 @@ public class DefaultMaven
|
|||
throws MavenExecutionException, BuildFailureException
|
||||
{
|
||||
List projects;
|
||||
|
||||
List files;
|
||||
try
|
||||
{
|
||||
List files = getProjectFiles( request );
|
||||
|
||||
projects = collectProjects( files, request.getLocalRepository(), request.isRecursive(),
|
||||
request.getSettings(), globalProfileManager, !request.useReactor() );
|
||||
|
||||
files = getProjectFiles( request );
|
||||
}
|
||||
catch ( IOException e )
|
||||
{
|
||||
throw new MavenExecutionException( "Error processing projects for the reactor: " + e.getMessage(), e );
|
||||
throw new MavenExecutionException( "Error selecting project files for the reactor: " + e.getMessage(), e );
|
||||
}
|
||||
|
||||
try
|
||||
{
|
||||
projects = collectProjects( files, request.getLocalRepository(), request.isRecursive(),
|
||||
request.getSettings(), globalProfileManager, !request.useReactor() );
|
||||
|
||||
}
|
||||
catch ( ArtifactResolutionException e )
|
||||
{
|
||||
|
|
|
@ -0,0 +1,216 @@
|
|||
package org.apache.maven.execution;
|
||||
|
||||
import org.apache.maven.artifact.repository.ArtifactRepository;
|
||||
import org.apache.maven.context.BuildContext;
|
||||
import org.apache.maven.context.BuildContextManager;
|
||||
import org.apache.maven.context.ManagedBuildData;
|
||||
import org.apache.maven.settings.Settings;
|
||||
import org.apache.maven.wagon.events.TransferListener;
|
||||
|
||||
import java.io.File;
|
||||
import java.util.Collections;
|
||||
import java.util.Date;
|
||||
import java.util.List;
|
||||
import java.util.Properties;
|
||||
|
||||
/*
|
||||
* Copyright 2001-2005 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
/**
|
||||
* Build context object that supplies information about how Maven was invoked, including all of the
|
||||
* information available in the MavenExecutionRequest (in read-only form).
|
||||
*/
|
||||
public class ExecutionBuildContext
|
||||
implements ManagedBuildData
|
||||
{
|
||||
|
||||
public static final String BUILD_CONTEXT_KEY = ExecutionBuildContext.class.getName();
|
||||
|
||||
private final MavenExecutionRequest request;
|
||||
|
||||
public ExecutionBuildContext( MavenExecutionRequest request )
|
||||
{
|
||||
this.request = request;
|
||||
}
|
||||
|
||||
public List getActiveProfiles()
|
||||
{
|
||||
return Collections.unmodifiableList( request.getActiveProfiles() );
|
||||
}
|
||||
|
||||
public String getBaseDirectory()
|
||||
{
|
||||
return request.getBaseDirectory();
|
||||
}
|
||||
|
||||
public String getGlobalChecksumPolicy()
|
||||
{
|
||||
return request.getGlobalChecksumPolicy();
|
||||
}
|
||||
|
||||
public List getGoals()
|
||||
{
|
||||
return Collections.unmodifiableList( request.getGoals() );
|
||||
}
|
||||
|
||||
public List getInactiveProfiles()
|
||||
{
|
||||
return Collections.unmodifiableList( request.getInactiveProfiles() );
|
||||
}
|
||||
|
||||
public ArtifactRepository getLocalRepository()
|
||||
{
|
||||
return request.getLocalRepository();
|
||||
}
|
||||
|
||||
public File getLocalRepositoryPath()
|
||||
{
|
||||
return request.getLocalRepositoryPath();
|
||||
}
|
||||
|
||||
public int getLoggingLevel()
|
||||
{
|
||||
return request.getLoggingLevel();
|
||||
}
|
||||
|
||||
public List getMirrors()
|
||||
{
|
||||
return Collections.unmodifiableList( request.getMirrors() );
|
||||
}
|
||||
|
||||
public List getPluginGroups()
|
||||
{
|
||||
return Collections.unmodifiableList( request.getPluginGroups() );
|
||||
}
|
||||
|
||||
public String getPomFile()
|
||||
{
|
||||
return request.getPomFile();
|
||||
}
|
||||
|
||||
public List getProfiles()
|
||||
{
|
||||
return Collections.unmodifiableList( request.getProfiles() );
|
||||
}
|
||||
|
||||
public Properties getProperties()
|
||||
{
|
||||
return new Properties( request.getProperties() );
|
||||
}
|
||||
|
||||
public List getProxies()
|
||||
{
|
||||
return Collections.unmodifiableList( request.getProxies() );
|
||||
}
|
||||
|
||||
public String getReactorFailureBehavior()
|
||||
{
|
||||
return request.getReactorFailureBehavior();
|
||||
}
|
||||
|
||||
public List getServers()
|
||||
{
|
||||
return Collections.unmodifiableList( request.getServers() );
|
||||
}
|
||||
|
||||
public Settings getSettings()
|
||||
{
|
||||
return request.getSettings();
|
||||
}
|
||||
|
||||
public String getSettingsFile()
|
||||
{
|
||||
return request.getSettingsFile();
|
||||
}
|
||||
|
||||
public Date getStartTime()
|
||||
{
|
||||
return request.getStartTime();
|
||||
}
|
||||
|
||||
public TransferListener getTransferListener()
|
||||
{
|
||||
return request.getTransferListener();
|
||||
}
|
||||
|
||||
public boolean isInteractiveMode()
|
||||
{
|
||||
return request.isInteractiveMode();
|
||||
}
|
||||
|
||||
public boolean isNoSnapshotUpdates()
|
||||
{
|
||||
return request.isNoSnapshotUpdates();
|
||||
}
|
||||
|
||||
public boolean isOffline()
|
||||
{
|
||||
return request.isOffline();
|
||||
}
|
||||
|
||||
public boolean isRecursive()
|
||||
{
|
||||
return request.isRecursive();
|
||||
}
|
||||
|
||||
public boolean isShowErrors()
|
||||
{
|
||||
return request.isShowErrors();
|
||||
}
|
||||
|
||||
public boolean isUpdateSnapshots()
|
||||
{
|
||||
return request.isUpdateSnapshots();
|
||||
}
|
||||
|
||||
public boolean isUsePluginRegistry()
|
||||
{
|
||||
return request.isUsePluginRegistry();
|
||||
}
|
||||
|
||||
public boolean isUsePluginUpdateOverride()
|
||||
{
|
||||
return request.isUsePluginUpdateOverride();
|
||||
}
|
||||
|
||||
public String getStorageKey()
|
||||
{
|
||||
return BUILD_CONTEXT_KEY;
|
||||
}
|
||||
|
||||
public static ExecutionBuildContext readExecutionBuildContext( BuildContextManager buildContextManager )
|
||||
{
|
||||
BuildContext buildContext = buildContextManager.readBuildContext( false );
|
||||
|
||||
ExecutionBuildContext executionContext = null;
|
||||
|
||||
if ( buildContext != null )
|
||||
{
|
||||
executionContext = (ExecutionBuildContext) buildContext.get( BUILD_CONTEXT_KEY );
|
||||
}
|
||||
|
||||
return executionContext;
|
||||
}
|
||||
|
||||
public void store( BuildContextManager buildContextManager )
|
||||
{
|
||||
BuildContext buildContext = buildContextManager.readBuildContext( true );
|
||||
|
||||
buildContext.put( this );
|
||||
|
||||
buildContextManager.storeBuildContext( buildContext );
|
||||
}
|
||||
}
|
|
@ -80,6 +80,10 @@
|
|||
<role>org.apache.maven.Maven</role>
|
||||
<implementation>org.apache.maven.DefaultMaven</implementation>
|
||||
<requirements>
|
||||
<requirement>
|
||||
<role>org.apache.maven.context.BuildContextManager</role>
|
||||
<role-hint>default</role-hint>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.project.MavenProjectBuilder</role>
|
||||
</requirement>
|
||||
|
|
|
@ -2629,6 +2629,16 @@
|
|||
<type>ActivationFile</type>
|
||||
</association>
|
||||
</field>
|
||||
<field>
|
||||
<name>custom</name>
|
||||
<version>4.0.0</version>
|
||||
<description>
|
||||
Describes a custom profile activation trigger, brought in via build extension.
|
||||
</description>
|
||||
<association>
|
||||
<type>ActivationCustom</type>
|
||||
</association>
|
||||
</field>
|
||||
</fields>
|
||||
</class>
|
||||
<class>
|
||||
|
@ -2714,6 +2724,32 @@
|
|||
</field>
|
||||
</fields>
|
||||
</class>
|
||||
<class>
|
||||
<name>ActivationCustom</name>
|
||||
<version>4.0.0</version>
|
||||
<description><![CDATA[
|
||||
This activation allows users to specify their own custom trigger for a profile.
|
||||
]]></description>
|
||||
<fields>
|
||||
<field>
|
||||
<name>configuration</name>
|
||||
<version>4.0.0</version>
|
||||
<type>DOM</type>
|
||||
<description><![CDATA[
|
||||
The specification for triggering the profile according to the rules of the custom
|
||||
activation type.
|
||||
]]></description>
|
||||
</field>
|
||||
<field>
|
||||
<name>type</name>
|
||||
<version>4.0.0</version>
|
||||
<type>String</type>
|
||||
<description><![CDATA[
|
||||
The type (role-hint) of activation which is to be used to activate the profile.
|
||||
]]></description>
|
||||
</field>
|
||||
</fields>
|
||||
</class>
|
||||
<!-- /BuildProfile support -->
|
||||
<class xml.tagName="plugin">
|
||||
<name>ReportPlugin</name>
|
||||
|
|
|
@ -29,6 +29,11 @@
|
|||
<description>This library is used to not only read Maven project object model files, but to assemble inheritence
|
||||
and to retrieve remote models as required.</description>
|
||||
<dependencies>
|
||||
<dependency>
|
||||
<groupId>org.apache.maven</groupId>
|
||||
<artifactId>maven-build-context</artifactId>
|
||||
<version>2.1-SNAPSHOT</version>
|
||||
</dependency>
|
||||
<dependency>
|
||||
<groupId>org.apache.maven</groupId>
|
||||
<artifactId>maven-artifact-test</artifactId>
|
||||
|
|
|
@ -0,0 +1,137 @@
|
|||
package org.apache.maven.profiles.activation;
|
||||
|
||||
import org.apache.maven.model.Activation;
|
||||
import org.apache.maven.model.ActivationCustom;
|
||||
import org.apache.maven.model.Profile;
|
||||
import org.codehaus.plexus.PlexusConstants;
|
||||
import org.codehaus.plexus.PlexusContainer;
|
||||
import org.codehaus.plexus.component.configurator.BasicComponentConfigurator;
|
||||
import org.codehaus.plexus.component.configurator.ComponentConfigurationException;
|
||||
import org.codehaus.plexus.component.configurator.ComponentConfigurator;
|
||||
import org.codehaus.plexus.component.repository.exception.ComponentLookupException;
|
||||
import org.codehaus.plexus.configuration.PlexusConfiguration;
|
||||
import org.codehaus.plexus.configuration.xml.XmlPlexusConfiguration;
|
||||
import org.codehaus.plexus.context.Context;
|
||||
import org.codehaus.plexus.context.ContextException;
|
||||
import org.codehaus.plexus.logging.LogEnabled;
|
||||
import org.codehaus.plexus.logging.Logger;
|
||||
import org.codehaus.plexus.logging.console.ConsoleLogger;
|
||||
import org.codehaus.plexus.personality.plexus.lifecycle.phase.Contextualizable;
|
||||
import org.codehaus.plexus.util.xml.Xpp3Dom;
|
||||
|
||||
/*
|
||||
* Copyright 2001-2005 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
/**
|
||||
* Profile activator that allows the use of custom third-party activators, by specifying a type -
|
||||
* or role-hint - for the activator, along with a configuration (in the form of a DOM) to be used
|
||||
* in configuring the activator. This activator will lookup/configure custom activators on-the-fly,
|
||||
* without caching any of the lookups from the container.
|
||||
*/
|
||||
public class CustomActivator
|
||||
implements ProfileActivator, Contextualizable, LogEnabled
|
||||
{
|
||||
|
||||
private PlexusContainer container;
|
||||
|
||||
private Logger logger;
|
||||
|
||||
public boolean canDetermineActivation( Profile profile )
|
||||
{
|
||||
Activation activation = profile.getActivation();
|
||||
|
||||
if ( activation != null )
|
||||
{
|
||||
ActivationCustom custom = activation.getCustom();
|
||||
|
||||
if ( custom != null )
|
||||
{
|
||||
ProfileActivator activator = loadProfileActivator( custom );
|
||||
|
||||
return activator.canDetermineActivation( profile );
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
private ProfileActivator loadProfileActivator( ActivationCustom custom )
|
||||
{
|
||||
String type = custom.getType();
|
||||
|
||||
ProfileActivator activator;
|
||||
try
|
||||
{
|
||||
activator = (ProfileActivator) container.lookup( ProfileActivator.ROLE, type );
|
||||
}
|
||||
catch ( ComponentLookupException e )
|
||||
{
|
||||
getLogger().debug( "Failed to lookup ProfileActivator \'" + type + "\'", e );
|
||||
|
||||
throw new IllegalArgumentException( "Cannot find ProfileActivator with role-hint: " + type
|
||||
+ ". \nPerhaps you're missing a build extension? \nSee debug output for more information." );
|
||||
}
|
||||
|
||||
PlexusConfiguration configuration = new XmlPlexusConfiguration( (Xpp3Dom) custom.getConfiguration() );
|
||||
|
||||
ComponentConfigurator configurator = new BasicComponentConfigurator();
|
||||
|
||||
try
|
||||
{
|
||||
configurator.configureComponent( activator, configuration, container.getContainerRealm() );
|
||||
}
|
||||
catch ( ComponentConfigurationException e )
|
||||
{
|
||||
getLogger().debug( "Failed to configure ProfileActivator \'" + type + "\'", e );
|
||||
|
||||
throw new IllegalArgumentException( "Failed to configure ProfileActivator with role-hint: " + type
|
||||
+ ". Turn on debug mode for more information." );
|
||||
}
|
||||
|
||||
return activator;
|
||||
}
|
||||
|
||||
public boolean isActive( Profile profile )
|
||||
{
|
||||
ActivationCustom custom = profile.getActivation().getCustom();
|
||||
|
||||
ProfileActivator activator = loadProfileActivator( custom );
|
||||
|
||||
return activator.isActive( profile );
|
||||
}
|
||||
|
||||
public void contextualize( Context context )
|
||||
throws ContextException
|
||||
{
|
||||
this.container = (PlexusContainer) context.get( PlexusConstants.PLEXUS_KEY );
|
||||
}
|
||||
|
||||
private Logger getLogger()
|
||||
{
|
||||
if ( logger == null )
|
||||
{
|
||||
logger = new ConsoleLogger( Logger.LEVEL_DEBUG, "CustomActivator-instantiated" );
|
||||
}
|
||||
|
||||
return logger;
|
||||
}
|
||||
|
||||
public void enableLogging( Logger logger )
|
||||
{
|
||||
this.logger = logger;
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,25 @@
|
|||
package org.apache.maven.profiles.activation;
|
||||
|
||||
import org.codehaus.plexus.component.configurator.expression.ExpressionEvaluationException;
|
||||
import org.codehaus.plexus.component.configurator.expression.ExpressionEvaluator;
|
||||
|
||||
import java.io.File;
|
||||
|
||||
public class CustomActivatorExpressionEvaluator
|
||||
implements ExpressionEvaluator
|
||||
{
|
||||
|
||||
public File alignToBaseDirectory( File file )
|
||||
{
|
||||
// TODO Auto-generated method stub
|
||||
return null;
|
||||
}
|
||||
|
||||
public Object evaluate( String expression )
|
||||
throws ExpressionEvaluationException
|
||||
{
|
||||
// TODO Auto-generated method stub
|
||||
return null;
|
||||
}
|
||||
|
||||
}
|
|
@ -1,5 +1,6 @@
|
|||
package org.apache.maven.profiles.activation;
|
||||
|
||||
import org.apache.maven.context.BuildContextManager;
|
||||
import org.apache.maven.model.Profile;
|
||||
|
||||
/*
|
||||
|
@ -21,6 +22,8 @@ import org.apache.maven.model.Profile;
|
|||
public abstract class DetectedProfileActivator
|
||||
implements ProfileActivator
|
||||
{
|
||||
private BuildContextManager buildContextManager;
|
||||
|
||||
public boolean canDetermineActivation( Profile profile )
|
||||
{
|
||||
return canDetectActivation( profile );
|
||||
|
@ -28,4 +31,9 @@ public abstract class DetectedProfileActivator
|
|||
|
||||
protected abstract boolean canDetectActivation( Profile profile );
|
||||
|
||||
protected BuildContextManager getBuildContextManager()
|
||||
{
|
||||
return buildContextManager;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -22,9 +22,10 @@ import org.codehaus.plexus.util.FileUtils;
|
|||
*/
|
||||
|
||||
public class FileProfileActivator
|
||||
extends DetectedProfileActivator
|
||||
implements ProfileActivator
|
||||
{
|
||||
protected boolean canDetectActivation( Profile profile )
|
||||
|
||||
public boolean canDetermineActivation( Profile profile )
|
||||
{
|
||||
return profile.getActivation() != null && profile.getActivation().getFile() != null;
|
||||
}
|
||||
|
@ -56,4 +57,5 @@ public class FileProfileActivator
|
|||
|
||||
return false;
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -1,5 +1,6 @@
|
|||
package org.apache.maven.profiles.activation;
|
||||
|
||||
import org.apache.maven.context.SystemBuildContext;
|
||||
import org.apache.maven.model.Activation;
|
||||
import org.apache.maven.model.Profile;
|
||||
import org.codehaus.plexus.util.StringUtils;
|
||||
|
@ -23,7 +24,8 @@ import org.codehaus.plexus.util.StringUtils;
|
|||
public class JdkPrefixProfileActivator
|
||||
extends DetectedProfileActivator
|
||||
{
|
||||
private static final String JDK_VERSION = System.getProperty( "java.version" );
|
||||
|
||||
public static final String JDK_VERSION = "java.version";
|
||||
|
||||
public boolean isActive( Profile profile )
|
||||
{
|
||||
|
@ -39,8 +41,11 @@ public class JdkPrefixProfileActivator
|
|||
jdk = jdk.substring( 1 );
|
||||
}
|
||||
|
||||
SystemBuildContext systemContext = SystemBuildContext.getSystemBuildContext( getBuildContextManager(), true );
|
||||
String javaVersion = systemContext.getSystemProperty( JDK_VERSION );
|
||||
|
||||
// null case is covered by canDetermineActivation(), so we can do a straight startsWith() here.
|
||||
boolean result = JDK_VERSION.startsWith( jdk );
|
||||
boolean result = javaVersion.startsWith( jdk );
|
||||
|
||||
if ( reverse )
|
||||
{
|
||||
|
|
|
@ -1,15 +1,12 @@
|
|||
package org.apache.maven.profiles.activation;
|
||||
|
||||
import java.util.Properties;
|
||||
import org.apache.maven.context.SystemBuildContext;
|
||||
import org.apache.maven.model.Activation;
|
||||
import org.apache.maven.model.ActivationProperty;
|
||||
import org.apache.maven.model.Profile;
|
||||
import org.codehaus.plexus.context.Context;
|
||||
import org.codehaus.plexus.context.ContextException;
|
||||
import org.codehaus.plexus.logging.LogEnabled;
|
||||
import org.codehaus.plexus.logging.Logger;
|
||||
import org.codehaus.plexus.logging.console.ConsoleLogger;
|
||||
import org.codehaus.plexus.personality.plexus.lifecycle.phase.Contextualizable;
|
||||
import org.codehaus.plexus.util.StringUtils;
|
||||
|
||||
/*
|
||||
|
@ -29,16 +26,11 @@ import org.codehaus.plexus.util.StringUtils;
|
|||
*/
|
||||
|
||||
public class SystemPropertyProfileActivator
|
||||
extends DetectedProfileActivator implements Contextualizable, LogEnabled
|
||||
extends DetectedProfileActivator
|
||||
implements LogEnabled
|
||||
{
|
||||
private Context context;
|
||||
private Logger logger;
|
||||
|
||||
public void contextualize(Context context) throws ContextException
|
||||
{
|
||||
this.context = context;
|
||||
}
|
||||
|
||||
protected boolean canDetectActivation( Profile profile )
|
||||
{
|
||||
return profile.getActivation() != null && profile.getActivation().getProperty() != null;
|
||||
|
@ -46,30 +38,14 @@ public class SystemPropertyProfileActivator
|
|||
|
||||
public boolean isActive( Profile profile )
|
||||
{
|
||||
Properties properties = null;
|
||||
if ( context.contains( "SystemProperties" ) )
|
||||
{
|
||||
try
|
||||
{
|
||||
properties = (Properties) context.get("SystemProperties");
|
||||
}
|
||||
catch ( ContextException e )
|
||||
{
|
||||
getLogger().debug( "Failed to get system properties cache from context.", e );
|
||||
}
|
||||
}
|
||||
|
||||
if ( properties == null )
|
||||
{
|
||||
properties = System.getProperties();
|
||||
}
|
||||
|
||||
Activation activation = profile.getActivation();
|
||||
|
||||
ActivationProperty property = activation.getProperty();
|
||||
|
||||
if ( property != null )
|
||||
{
|
||||
SystemBuildContext systemBuildContext = SystemBuildContext.getSystemBuildContext( getBuildContextManager(), true );
|
||||
|
||||
String name = property.getName();
|
||||
boolean reverseName = false;
|
||||
|
||||
|
@ -79,7 +55,7 @@ public class SystemPropertyProfileActivator
|
|||
name = name.substring( 1 );
|
||||
}
|
||||
|
||||
String sysValue = properties != null ? properties.getProperty( name ) : null;
|
||||
String sysValue = systemBuildContext.getSystemProperty( name );
|
||||
|
||||
String propValue = property.getValue();
|
||||
if ( StringUtils.isNotEmpty( propValue ) )
|
||||
|
|
|
@ -33,6 +33,7 @@ import org.apache.maven.artifact.resolver.ArtifactResolutionResult;
|
|||
import org.apache.maven.artifact.resolver.ArtifactResolver;
|
||||
import org.apache.maven.artifact.versioning.InvalidVersionSpecificationException;
|
||||
import org.apache.maven.artifact.versioning.VersionRange;
|
||||
import org.apache.maven.context.BuildContextManager;
|
||||
import org.apache.maven.model.Build;
|
||||
import org.apache.maven.model.Dependency;
|
||||
import org.apache.maven.model.DependencyManagement;
|
||||
|
@ -40,16 +41,14 @@ import org.apache.maven.model.DistributionManagement;
|
|||
import org.apache.maven.model.Extension;
|
||||
import org.apache.maven.model.Model;
|
||||
import org.apache.maven.model.Plugin;
|
||||
import org.apache.maven.model.Profile;
|
||||
import org.apache.maven.model.ReportPlugin;
|
||||
import org.apache.maven.model.io.xpp3.MavenXpp3Reader;
|
||||
import org.apache.maven.profiles.DefaultProfileManager;
|
||||
import org.apache.maven.profiles.MavenProfilesBuilder;
|
||||
import org.apache.maven.profiles.ProfileManager;
|
||||
import org.apache.maven.profiles.ProfilesConversionUtils;
|
||||
import org.apache.maven.profiles.ProfilesRoot;
|
||||
import org.apache.maven.profiles.activation.ProfileActivationException;
|
||||
import org.apache.maven.project.artifact.InvalidDependencyVersionException;
|
||||
import org.apache.maven.project.build.ProjectBuildContext;
|
||||
import org.apache.maven.project.build.model.DefaultModelLineage;
|
||||
import org.apache.maven.project.build.model.ModelLineage;
|
||||
import org.apache.maven.project.build.model.ModelLineageBuilder;
|
||||
|
@ -150,8 +149,6 @@ public class DefaultMavenProjectBuilder
|
|||
|
||||
private ModelInheritanceAssembler modelInheritanceAssembler;
|
||||
|
||||
private ProfileInjector profileInjector;
|
||||
|
||||
private ModelValidator validator;
|
||||
|
||||
private Map processedProjectCache = new HashMap();
|
||||
|
@ -167,12 +164,12 @@ public class DefaultMavenProjectBuilder
|
|||
|
||||
private ModelInterpolator modelInterpolator;
|
||||
|
||||
private ArtifactRepositoryFactory artifactRepositoryFactory;
|
||||
|
||||
private ModelLineageBuilder modelLineageBuilder;
|
||||
|
||||
private ProfileAdvisor profileAdvisor;
|
||||
|
||||
private BuildContextManager buildContextManager;
|
||||
|
||||
private MavenTools mavenTools;
|
||||
|
||||
// ----------------------------------------------------------------------
|
||||
|
@ -263,18 +260,31 @@ public class DefaultMavenProjectBuilder
|
|||
|
||||
superModel.setVersion( STANDALONE_SUPERPOM_VERSION );
|
||||
|
||||
MavenProject project = new MavenProject( superModel );
|
||||
|
||||
List activeProfiles;
|
||||
ProjectBuildContext projectContext = ProjectBuildContext.getProjectBuildContext( buildContextManager, true );
|
||||
|
||||
profileManager.addProfiles( superModel.getProfiles() );
|
||||
projectContext.setCurrentProject( project );
|
||||
projectContext.store( buildContextManager );
|
||||
|
||||
String projectId = safeVersionlessKey( STANDALONE_SUPERPOM_GROUPID, STANDALONE_SUPERPOM_ARTIFACTID );
|
||||
|
||||
activeProfiles = injectActiveProfiles( profileManager, superModel );
|
||||
List activeProfiles = profileAdvisor.applyActivatedProfiles( superModel, null, profileManager.getExplicitlyActivatedIds(), profileManager.getExplicitlyDeactivatedIds() );
|
||||
List activeExternalProfiles = profileAdvisor.applyActivatedExternalProfiles( superModel, null, profileManager );
|
||||
|
||||
MavenProject project = new MavenProject( superModel );
|
||||
LinkedHashSet profiles = new LinkedHashSet();
|
||||
|
||||
project.setActiveProfiles( activeProfiles );
|
||||
if ( activeProfiles != null && !activeProfiles.isEmpty() )
|
||||
{
|
||||
profiles.addAll( activeProfiles );
|
||||
}
|
||||
|
||||
if ( activeExternalProfiles != null && !activeExternalProfiles.isEmpty() )
|
||||
{
|
||||
profiles.addAll( activeExternalProfiles );
|
||||
}
|
||||
|
||||
project.setActiveProfiles( new ArrayList( profiles ) );
|
||||
|
||||
project.setOriginalModel( superModel );
|
||||
|
||||
|
@ -296,6 +306,7 @@ public class DefaultMavenProjectBuilder
|
|||
}
|
||||
}
|
||||
|
||||
|
||||
public MavenProject buildWithDependencies( File projectDescriptor,
|
||||
ArtifactRepository localRepository,
|
||||
ProfileManager profileManager )
|
||||
|
@ -1001,6 +1012,11 @@ public class DefaultMavenProjectBuilder
|
|||
|
||||
modelLineageBuilder.resumeBuildingModelLineage( modelLineage, localRepository, externalProfileManager, cachedPomFilesByModelId );
|
||||
|
||||
ProjectBuildContext projectContext = ProjectBuildContext.getProjectBuildContext( buildContextManager, true );
|
||||
|
||||
projectContext.setModelLineage( modelLineage );
|
||||
projectContext.store( buildContextManager );
|
||||
|
||||
List explicitlyActive;
|
||||
List explicitlyInactive;
|
||||
|
||||
|
@ -1027,6 +1043,9 @@ public class DefaultMavenProjectBuilder
|
|||
MavenProject project = new MavenProject( currentModel );
|
||||
project.setFile( currentPom );
|
||||
|
||||
projectContext.setCurrentProject( project );
|
||||
projectContext.store( buildContextManager );
|
||||
|
||||
project.setActiveProfiles( profileAdvisor.applyActivatedProfiles( model, projectDir, explicitlyActive,
|
||||
explicitlyInactive ) );
|
||||
|
||||
|
@ -1061,80 +1080,6 @@ public class DefaultMavenProjectBuilder
|
|||
return result;
|
||||
}
|
||||
|
||||
private List injectActiveProfiles( ProfileManager profileManager, Model model )
|
||||
throws ProjectBuildingException
|
||||
{
|
||||
List activeProfiles;
|
||||
|
||||
if ( profileManager != null )
|
||||
{
|
||||
try
|
||||
{
|
||||
activeProfiles = profileManager.getActiveProfiles();
|
||||
}
|
||||
catch ( ProfileActivationException e )
|
||||
{
|
||||
String projectId = safeVersionlessKey( model.getGroupId(), model.getArtifactId() );
|
||||
|
||||
throw new ProjectBuildingException( projectId, e.getMessage(), e );
|
||||
}
|
||||
|
||||
for ( Iterator it = activeProfiles.iterator(); it.hasNext(); )
|
||||
{
|
||||
Profile profile = (Profile) it.next();
|
||||
|
||||
profileInjector.inject( profile, model );
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
activeProfiles = Collections.EMPTY_LIST;
|
||||
}
|
||||
|
||||
return activeProfiles;
|
||||
}
|
||||
|
||||
private void loadProjectExternalProfiles( ProfileManager profileManager, File projectDir )
|
||||
throws ProfileActivationException
|
||||
{
|
||||
if ( projectDir != null )
|
||||
{
|
||||
try
|
||||
{
|
||||
ProfilesRoot root = profilesBuilder.buildProfiles( projectDir );
|
||||
|
||||
if ( root != null )
|
||||
{
|
||||
List active = root.getActiveProfiles();
|
||||
|
||||
if ( active != null && !active.isEmpty() )
|
||||
{
|
||||
profileManager.explicitlyActivate( root.getActiveProfiles() );
|
||||
}
|
||||
|
||||
for ( Iterator it = root.getProfiles().iterator(); it.hasNext(); )
|
||||
{
|
||||
org.apache.maven.profiles.Profile rawProfile = (org.apache.maven.profiles.Profile) it.next();
|
||||
|
||||
Profile converted = ProfilesConversionUtils.convertFromProfileXmlProfile( rawProfile );
|
||||
|
||||
profileManager.addProfile( converted );
|
||||
}
|
||||
}
|
||||
}
|
||||
catch ( IOException e )
|
||||
{
|
||||
throw new ProfileActivationException( "Cannot read profiles.xml resource from directory: " + projectDir,
|
||||
e );
|
||||
}
|
||||
catch ( XmlPullParserException e )
|
||||
{
|
||||
throw new ProfileActivationException(
|
||||
"Cannot parse profiles.xml resource from directory: " + projectDir, e );
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private Model readModel( String projectId, File file, boolean strict )
|
||||
throws ProjectBuildingException
|
||||
{
|
||||
|
|
|
@ -0,0 +1,98 @@
|
|||
package org.apache.maven.project.build;
|
||||
|
||||
import org.apache.maven.context.BuildContext;
|
||||
import org.apache.maven.context.BuildContextManager;
|
||||
import org.apache.maven.context.ManagedBuildData;
|
||||
import org.apache.maven.project.MavenProject;
|
||||
import org.apache.maven.project.build.model.ModelLineage;
|
||||
|
||||
/*
|
||||
* Copyright 2001-2005 The Apache Software Foundation.
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*/
|
||||
|
||||
/**
|
||||
* Build context information available for use during profile activation, which supplies information
|
||||
* about the current project and lineage from the current project back through parent poms to the
|
||||
* POM that declared that profile (where the activator is used). Lineage may not be accessible in
|
||||
* all cases, and will usually be incomplete (not stretching all the way back to the common super-POM).
|
||||
* This could enable custom profile activators that trigger based on model properties, etc.
|
||||
*/
|
||||
public class ProjectBuildContext
|
||||
implements ManagedBuildData
|
||||
{
|
||||
|
||||
public static final String BUILD_CONTEXT_KEY = ProjectBuildContext.class.getName();
|
||||
|
||||
private ModelLineage modelLineage;
|
||||
|
||||
private MavenProject currentProject;
|
||||
|
||||
public ProjectBuildContext()
|
||||
{
|
||||
}
|
||||
|
||||
public ModelLineage getModelLineage()
|
||||
{
|
||||
return modelLineage;
|
||||
}
|
||||
|
||||
public void setModelLineage( ModelLineage modelLineage )
|
||||
{
|
||||
this.modelLineage = modelLineage;
|
||||
}
|
||||
|
||||
public MavenProject getCurrentProject()
|
||||
{
|
||||
return currentProject;
|
||||
}
|
||||
|
||||
public void setCurrentProject( MavenProject currentProject )
|
||||
{
|
||||
this.currentProject = currentProject;
|
||||
}
|
||||
|
||||
public String getStorageKey()
|
||||
{
|
||||
return BUILD_CONTEXT_KEY;
|
||||
}
|
||||
|
||||
public static ProjectBuildContext getProjectBuildContext( BuildContextManager buildContextManager, boolean create )
|
||||
{
|
||||
BuildContext buildContext = buildContextManager.readBuildContext( false );
|
||||
|
||||
ProjectBuildContext projectContext = null;
|
||||
|
||||
if ( buildContext != null )
|
||||
{
|
||||
projectContext = (ProjectBuildContext) buildContext.get( BUILD_CONTEXT_KEY );
|
||||
}
|
||||
|
||||
if ( create && projectContext == null )
|
||||
{
|
||||
projectContext = new ProjectBuildContext();
|
||||
}
|
||||
|
||||
return projectContext;
|
||||
}
|
||||
|
||||
public void store( BuildContextManager buildContextManager )
|
||||
{
|
||||
BuildContext buildContext = buildContextManager.readBuildContext( true );
|
||||
|
||||
buildContext.put( this );
|
||||
|
||||
buildContextManager.storeBuildContext( buildContext );
|
||||
}
|
||||
}
|
|
@ -328,4 +328,44 @@ public class DefaultModelLineage
|
|||
}
|
||||
}
|
||||
|
||||
public ModelLineageIterator lineageIterator()
|
||||
{
|
||||
return new ModelLineageIterator()
|
||||
{
|
||||
|
||||
private int idx = -1;
|
||||
|
||||
public boolean hasNext()
|
||||
{
|
||||
return tuples.size() > idx + 1;
|
||||
}
|
||||
|
||||
public Object next()
|
||||
{
|
||||
return ( (ModelLineageTuple) tuples.get( ( ++idx ) ) ).model;
|
||||
}
|
||||
|
||||
public void remove()
|
||||
{
|
||||
tuples.remove( idx );
|
||||
}
|
||||
|
||||
public List getArtifactRepositories()
|
||||
{
|
||||
return ( (ModelLineageTuple) tuples.get( idx ) ).remoteRepositories;
|
||||
}
|
||||
|
||||
public Model getModel()
|
||||
{
|
||||
return ( (ModelLineageTuple) tuples.get( idx ) ).model;
|
||||
}
|
||||
|
||||
public File getPOMFile()
|
||||
{
|
||||
return ( (ModelLineageTuple) tuples.get( idx ) ).file;
|
||||
}
|
||||
|
||||
};
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -89,6 +89,14 @@ public interface ModelLineage
|
|||
*/
|
||||
List getArtifactRepositoryListsInDescendingOrder();
|
||||
|
||||
/**
|
||||
* Retrieve an Iterator derivative that functions in the simplest sense just like the return
|
||||
* value of the modelIterator() method. However, the ModelLineageIterator also gives access to
|
||||
* the current POM file and current remote ArtifactRepository instances used to resolve the
|
||||
* current Model...along with a method to give explicit access to the current Model instance.
|
||||
*/
|
||||
ModelLineageIterator lineageIterator();
|
||||
|
||||
/**
|
||||
* Iterate over the lineage of Model instances, starting with the child (current) Model,
|
||||
* and ending with the deepest ancestor.
|
||||
|
|
|
@ -0,0 +1,37 @@
|
|||
package org.apache.maven.project.build.model;
|
||||
|
||||
import org.apache.maven.model.Model;
|
||||
|
||||
import java.io.File;
|
||||
import java.util.Iterator;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* Iterator that gives access to all information associated with each model in a ModelLineage.
|
||||
* The result of the next() method is the Model instance itself, but you can also retrieve this
|
||||
* Model instance using getModel() below.
|
||||
*
|
||||
* @author jdcasey
|
||||
*/
|
||||
public interface ModelLineageIterator
|
||||
extends Iterator
|
||||
{
|
||||
|
||||
/**
|
||||
* Retrieve the Model instance associated with the current position in the ModelLineage.
|
||||
* This is the same return value as the next() method.
|
||||
*/
|
||||
Model getModel();
|
||||
|
||||
/**
|
||||
* Retrieve the POM File associated with the current position in the ModelLineage
|
||||
*/
|
||||
File getPOMFile();
|
||||
|
||||
/**
|
||||
* Retrieve the remote ArtifactRepository instances associated with the current position
|
||||
* in the ModelLineage.
|
||||
*/
|
||||
List getArtifactRepositories();
|
||||
|
||||
}
|
|
@ -101,9 +101,6 @@
|
|||
<requirement>
|
||||
<role>org.apache.maven.profiles.MavenProfilesBuilder</role>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.project.injection.ProfileInjector</role>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.project.injection.ModelDefaultsInjector</role>
|
||||
</requirement>
|
||||
|
@ -126,7 +123,8 @@
|
|||
<role>org.apache.maven.artifact.resolver.ArtifactResolver</role>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.artifact.repository.ArtifactRepositoryFactory</role>
|
||||
<role>org.apache.maven.context.BuildContextManager</role>
|
||||
<role-hint>default</role-hint>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.artifact.manager.WagonManager</role>
|
||||
|
@ -155,6 +153,12 @@
|
|||
<role>org.apache.maven.profiles.activation.ProfileActivator</role>
|
||||
<role-hint>jdk-prefix</role-hint>
|
||||
<implementation>org.apache.maven.profiles.activation.JdkPrefixProfileActivator</implementation>
|
||||
<requirements>
|
||||
<requirement>
|
||||
<role>org.apache.maven.context.BuildContextManager</role>
|
||||
<role-hint>default</role-hint>
|
||||
</requirement>
|
||||
</requirements>
|
||||
</component>
|
||||
<!--
|
||||
|
|
||||
|
@ -165,6 +169,12 @@
|
|||
<role>org.apache.maven.profiles.activation.ProfileActivator</role>
|
||||
<role-hint>system-property</role-hint>
|
||||
<implementation>org.apache.maven.profiles.activation.SystemPropertyProfileActivator</implementation>
|
||||
<requirements>
|
||||
<requirement>
|
||||
<role>org.apache.maven.context.BuildContextManager</role>
|
||||
<role-hint>default</role-hint>
|
||||
</requirement>
|
||||
</requirements>
|
||||
</component>
|
||||
<!--
|
||||
|
|
||||
|
@ -186,6 +196,16 @@
|
|||
<role-hint>file</role-hint>
|
||||
<implementation>org.apache.maven.profiles.activation.FileProfileActivator</implementation>
|
||||
</component>
|
||||
<!--
|
||||
|
|
||||
|
|
||||
|
|
||||
-->
|
||||
<component>
|
||||
<role>org.apache.maven.profiles.activation.ProfileActivator</role>
|
||||
<role-hint>custom</role-hint>
|
||||
<implementation>org.apache.maven.profiles.activation.CustomActivator</implementation>
|
||||
</component>
|
||||
<!--
|
||||
|
|
||||
|
|
||||
|
|
|
@ -1,9 +1,12 @@
|
|||
package org.apache.maven.profiles;
|
||||
|
||||
import org.apache.maven.context.BuildContextManager;
|
||||
import org.apache.maven.context.DefaultBuildContextManager;
|
||||
import org.apache.maven.context.SystemBuildContext;
|
||||
import org.apache.maven.model.Activation;
|
||||
import org.apache.maven.model.ActivationOS;
|
||||
import org.apache.maven.model.ActivationProperty;
|
||||
import org.apache.maven.model.Profile;
|
||||
import org.apache.maven.model.ActivationOS;
|
||||
import org.apache.maven.profiles.activation.ProfileActivationException;
|
||||
import org.codehaus.plexus.PlexusTestCase;
|
||||
|
||||
|
@ -13,8 +16,20 @@ public class DefaultProfileManagerTest
|
|||
extends PlexusTestCase
|
||||
{
|
||||
|
||||
private BuildContextManager buildContextManager;
|
||||
|
||||
public void setUp() throws Exception
|
||||
{
|
||||
super.setUp();
|
||||
|
||||
buildContextManager = (BuildContextManager) lookup( BuildContextManager.ROLE, DefaultBuildContextManager.ROLE_HINT );
|
||||
}
|
||||
|
||||
public void testShouldActivateDefaultProfile() throws ProfileActivationException
|
||||
{
|
||||
SystemBuildContext sysContext = SystemBuildContext.getSystemBuildContext( buildContextManager, true );
|
||||
sysContext.store( buildContextManager );
|
||||
|
||||
Profile notActivated = new Profile();
|
||||
notActivated.setId("notActivated");
|
||||
|
||||
|
@ -47,6 +62,9 @@ public class DefaultProfileManagerTest
|
|||
|
||||
public void testShouldNotActivateDefaultProfile() throws ProfileActivationException
|
||||
{
|
||||
SystemBuildContext sysContext = SystemBuildContext.getSystemBuildContext( buildContextManager, true );
|
||||
sysContext.store( buildContextManager );
|
||||
|
||||
Profile syspropActivated = new Profile();
|
||||
syspropActivated.setId("syspropActivated");
|
||||
|
||||
|
@ -82,6 +100,9 @@ public class DefaultProfileManagerTest
|
|||
|
||||
public void testShouldNotActivateReversalOfPresentSystemProperty() throws ProfileActivationException
|
||||
{
|
||||
SystemBuildContext sysContext = SystemBuildContext.getSystemBuildContext( buildContextManager, true );
|
||||
sysContext.store( buildContextManager );
|
||||
|
||||
Profile syspropActivated = new Profile();
|
||||
syspropActivated.setId("syspropActivated");
|
||||
|
||||
|
|
|
@ -1,21 +1,37 @@
|
|||
package org.apache.maven.profiles.activation;
|
||||
|
||||
import org.apache.maven.context.BuildContextManager;
|
||||
import org.apache.maven.context.DefaultBuildContextManager;
|
||||
import org.apache.maven.context.SystemBuildContext;
|
||||
import org.apache.maven.model.Activation;
|
||||
import org.apache.maven.model.ActivationProperty;
|
||||
import org.apache.maven.model.Profile;
|
||||
import org.codehaus.plexus.PlexusTestCase;
|
||||
import org.codehaus.plexus.context.ContextException;
|
||||
import org.codehaus.plexus.context.DefaultContext;
|
||||
|
||||
import java.util.Properties;
|
||||
|
||||
import junit.framework.TestCase;
|
||||
|
||||
public class SystemPropertyProfileActivatorTest
|
||||
extends TestCase
|
||||
extends PlexusTestCase
|
||||
{
|
||||
|
||||
private BuildContextManager buildContextManager;
|
||||
private SystemPropertyProfileActivator activator;
|
||||
|
||||
public void setUp() throws Exception
|
||||
{
|
||||
super.setUp();
|
||||
|
||||
buildContextManager = (BuildContextManager) lookup( BuildContextManager.ROLE, DefaultBuildContextManager.ROLE_HINT );
|
||||
|
||||
SystemBuildContext sysContext = SystemBuildContext.getSystemBuildContext( buildContextManager, true );
|
||||
sysContext.store( buildContextManager );
|
||||
|
||||
activator = (SystemPropertyProfileActivator) lookup( ProfileActivator.ROLE, "system-property" );
|
||||
}
|
||||
|
||||
public void testCanDetect_ShouldReturnTrueWhenActivationPropertyIsPresent()
|
||||
throws ContextException
|
||||
throws Exception
|
||||
{
|
||||
ActivationProperty prop = new ActivationProperty();
|
||||
prop.setName( "test" );
|
||||
|
@ -28,11 +44,11 @@ public class SystemPropertyProfileActivatorTest
|
|||
|
||||
profile.setActivation( activation );
|
||||
|
||||
assertTrue( buildProfileActivator().canDetermineActivation( profile ) );
|
||||
assertTrue( activator.canDetermineActivation( profile ) );
|
||||
}
|
||||
|
||||
public void testCanDetect_ShouldReturnFalseWhenActivationPropertyIsNotPresent()
|
||||
throws ContextException
|
||||
throws Exception
|
||||
{
|
||||
Activation activation = new Activation();
|
||||
|
||||
|
@ -40,11 +56,11 @@ public class SystemPropertyProfileActivatorTest
|
|||
|
||||
profile.setActivation( activation );
|
||||
|
||||
assertFalse( buildProfileActivator().canDetermineActivation( profile ) );
|
||||
assertFalse( activator.canDetermineActivation( profile ) );
|
||||
}
|
||||
|
||||
public void testIsActive_ShouldReturnTrueWhenPropertyNameSpecifiedAndPresent()
|
||||
throws ContextException
|
||||
throws Exception
|
||||
{
|
||||
ActivationProperty prop = new ActivationProperty();
|
||||
prop.setName( "test" );
|
||||
|
@ -59,11 +75,11 @@ public class SystemPropertyProfileActivatorTest
|
|||
|
||||
System.setProperty( "test", "true" );
|
||||
|
||||
assertTrue( buildProfileActivator().isActive( profile ) );
|
||||
assertTrue( activator.isActive( profile ) );
|
||||
}
|
||||
|
||||
public void testIsActive_ShouldReturnFalseWhenPropertyNameSpecifiedAndMissing()
|
||||
throws ContextException
|
||||
throws Exception
|
||||
{
|
||||
ActivationProperty prop = new ActivationProperty();
|
||||
prop.setName( "test" );
|
||||
|
@ -80,16 +96,7 @@ public class SystemPropertyProfileActivatorTest
|
|||
props.remove( "test" );
|
||||
System.setProperties( props );
|
||||
|
||||
assertFalse( buildProfileActivator().isActive( profile ) );
|
||||
}
|
||||
|
||||
private SystemPropertyProfileActivator buildProfileActivator()
|
||||
throws ContextException
|
||||
{
|
||||
SystemPropertyProfileActivator activator = new SystemPropertyProfileActivator();
|
||||
activator.contextualize( new DefaultContext() );
|
||||
|
||||
return activator;
|
||||
assertFalse( activator.isActive( profile ) );
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -71,6 +71,54 @@ public abstract class AbstractModelLineageTest
|
|||
assertEquals( 1, ml.size() );
|
||||
}
|
||||
|
||||
public void testLineageIterator_ShouldAddTwoEntriesAndIterateInFIFOOrder()
|
||||
throws IOException
|
||||
{
|
||||
ModelLineage ml = newModelLineage();
|
||||
|
||||
String gOne = "group1";
|
||||
String aOne = "artifact1";
|
||||
String vOne = "1";
|
||||
|
||||
Model mOne = new Model();
|
||||
|
||||
mOne.setGroupId( gOne );
|
||||
mOne.setArtifactId( aOne );
|
||||
mOne.setVersion( vOne );
|
||||
|
||||
File fOne = File.createTempFile( "ModelLineageTest.modelLineageIterator-test.", "" );
|
||||
fOne.deleteOnExit();
|
||||
|
||||
ml.setOrigin( mOne, fOne, null );
|
||||
|
||||
String gTwo = "group2";
|
||||
String aTwo = "artifact2";
|
||||
String vTwo = "2";
|
||||
|
||||
Model mTwo = new Model();
|
||||
|
||||
mOne.setGroupId( gTwo );
|
||||
mOne.setArtifactId( aTwo );
|
||||
mOne.setVersion( vTwo );
|
||||
|
||||
File fTwo = File.createTempFile( "ModelLineageTest.fileIterator-test.", "" );
|
||||
fTwo.deleteOnExit();
|
||||
|
||||
ml.addParent( mTwo, fTwo, null );
|
||||
|
||||
ModelLineageIterator it = ml.lineageIterator();
|
||||
|
||||
assertTrue( it.hasNext() );
|
||||
assertEquals( mOne.getId(), ( (Model) it.next() ).getId() );
|
||||
assertEquals( mOne.getId(), it.getModel().getId() );
|
||||
assertEquals( fOne, it.getPOMFile() );
|
||||
|
||||
assertTrue( it.hasNext() );
|
||||
assertEquals( mTwo.getId(), ( (Model) it.next() ).getId() );
|
||||
assertEquals( mTwo.getId(), it.getModel().getId() );
|
||||
assertEquals( fTwo, it.getPOMFile() );
|
||||
}
|
||||
|
||||
public void testModelIterator_ShouldAddTwoModelsAndIterateInFIFOOrder()
|
||||
{
|
||||
ModelLineage ml = newModelLineage();
|
||||
|
|
|
@ -19,6 +19,23 @@
|
|||
<role-hint>test</role-hint>
|
||||
<implementation>org.apache.maven.project.injection.TestProfileInjector</implementation>
|
||||
</component>
|
||||
<component>
|
||||
<role>org.apache.maven.project.build.profile.ProfileAdvisor</role>
|
||||
<role-hint>default</role-hint>
|
||||
<implementation>org.apache.maven.project.build.profile.DefaultProfileAdvisor</implementation>
|
||||
<requirements>
|
||||
<requirement>
|
||||
<role>org.apache.maven.MavenTools</role>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.profiles.MavenProfilesBuilder</role>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.project.injection.ProfileInjector</role>
|
||||
<role-hint>test</role-hint>
|
||||
</requirement>
|
||||
</requirements>
|
||||
</component>
|
||||
<component>
|
||||
<role>org.apache.maven.project.TestArtifactResolver</role>
|
||||
<implementation>org.apache.maven.project.TestArtifactResolver</implementation>
|
||||
|
@ -56,10 +73,6 @@
|
|||
<requirement>
|
||||
<role>org.apache.maven.project.injection.ModelDefaultsInjector</role>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.project.injection.ProfileInjector</role>
|
||||
<role-hint>test</role-hint>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.project.interpolation.ModelInterpolator</role>
|
||||
</requirement>
|
||||
|
@ -79,7 +92,8 @@
|
|||
<role>org.apache.maven.artifact.resolver.ArtifactResolver</role>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.artifact.repository.ArtifactRepositoryFactory</role>
|
||||
<role>org.apache.maven.context.BuildContextManager</role>
|
||||
<role-hint>default</role-hint>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.MavenTools</role>
|
||||
|
|
|
@ -37,6 +37,23 @@
|
|||
</requirement>
|
||||
</requirements>
|
||||
</component>
|
||||
<component>
|
||||
<role>org.apache.maven.project.build.profile.ProfileAdvisor</role>
|
||||
<role-hint>default</role-hint>
|
||||
<implementation>org.apache.maven.project.build.profile.DefaultProfileAdvisor</implementation>
|
||||
<requirements>
|
||||
<requirement>
|
||||
<role>org.apache.maven.MavenTools</role>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.profiles.MavenProfilesBuilder</role>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.project.injection.ProfileInjector</role>
|
||||
<role-hint>test</role-hint>
|
||||
</requirement>
|
||||
</requirements>
|
||||
</component>
|
||||
<component>
|
||||
<role>org.apache.maven.project.MavenProjectBuilder</role>
|
||||
<role-hint>test</role-hint>
|
||||
|
@ -56,10 +73,6 @@
|
|||
<requirement>
|
||||
<role>org.apache.maven.project.injection.ModelDefaultsInjector</role>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.project.injection.ProfileInjector</role>
|
||||
<role-hint>test</role-hint>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.project.interpolation.ModelInterpolator</role>
|
||||
</requirement>
|
||||
|
@ -79,10 +92,11 @@
|
|||
<role>org.apache.maven.artifact.resolver.ArtifactResolver</role>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.artifact.repository.ArtifactRepositoryFactory</role>
|
||||
<role>org.apache.maven.MavenTools</role>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.MavenTools</role>
|
||||
<role>org.apache.maven.context.BuildContextManager</role>
|
||||
<role-hint>default</role-hint>
|
||||
</requirement>
|
||||
</requirements>
|
||||
</component>
|
||||
|
|
2
pom.xml
2
pom.xml
|
@ -1,5 +1,4 @@
|
|||
<?xml version="1.0" encoding="UTF-8"?>
|
||||
|
||||
<!--
|
||||
~ Copyright 2005-2006 The Apache Software Foundation.
|
||||
~
|
||||
|
@ -149,6 +148,7 @@
|
|||
<module>maven-artifact</module>
|
||||
<module>maven-artifact-manager</module>
|
||||
<module>maven-artifact-test</module>
|
||||
<module>maven-build-context</module>
|
||||
<module>maven-core</module>
|
||||
<module>maven-error-diagnostics</module>
|
||||
<module>maven-model</module>
|
||||
|
|
Loading…
Reference in New Issue