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:
John Dennis Casey 2007-01-19 19:15:18 +00:00
parent 6c2268f0bd
commit dfc4a10c68
36 changed files with 1482 additions and 173 deletions

View File

@ -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>

View File

@ -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 );
}

View File

@ -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();
}

View File

@ -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 );
}
}

View File

@ -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;
}
}

View File

@ -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();
}

View File

@ -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 );
}
}

View File

@ -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>

View File

@ -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 ) );
}
}

View File

@ -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 ) );
}
}

View File

@ -0,0 +1,12 @@
package org.apache.maven.context;
public class DefaultBuildContextManagerTest
extends AbstractBuildContextManagerTest
{
protected String getRoleHintBeforeSetUp()
{
return DefaultBuildContextManager.ROLE_HINT;
}
}

View File

@ -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 ) );
}
}

View File

@ -27,6 +27,11 @@
<artifactId>maven-core</artifactId> <artifactId>maven-core</artifactId>
<name>Maven Core</name> <name>Maven Core</name>
<dependencies> <dependencies>
<dependency>
<groupId>org.apache.maven</groupId>
<artifactId>maven-build-context</artifactId>
<version>2.1-SNAPSHOT</version>
</dependency>
<dependency> <dependency>
<groupId>org.apache.maven</groupId> <groupId>org.apache.maven</groupId>
<artifactId>maven-settings</artifactId> <artifactId>maven-settings</artifactId>

View File

@ -20,8 +20,11 @@ package org.apache.maven;
import org.apache.maven.artifact.repository.ArtifactRepository; import org.apache.maven.artifact.repository.ArtifactRepository;
import org.apache.maven.artifact.resolver.ArtifactResolutionException; import org.apache.maven.artifact.resolver.ArtifactResolutionException;
import org.apache.maven.artifact.versioning.DefaultArtifactVersion; 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.BuildFailure;
import org.apache.maven.execution.DefaultMavenExecutionResult; import org.apache.maven.execution.DefaultMavenExecutionResult;
import org.apache.maven.execution.ExecutionBuildContext;
import org.apache.maven.execution.MavenExecutionRequest; import org.apache.maven.execution.MavenExecutionRequest;
import org.apache.maven.execution.MavenExecutionResult; import org.apache.maven.execution.MavenExecutionResult;
import org.apache.maven.execution.MavenSession; import org.apache.maven.execution.MavenSession;
@ -74,6 +77,8 @@ public class DefaultMaven
// Components // Components
// ---------------------------------------------------------------------- // ----------------------------------------------------------------------
protected BuildContextManager buildContextManager;
protected MavenProjectBuilder projectBuilder; protected MavenProjectBuilder projectBuilder;
protected LifecycleExecutor lifecycleExecutor; protected LifecycleExecutor lifecycleExecutor;
@ -98,6 +103,8 @@ public class DefaultMaven
{ {
request.setStartTime( new Date() ); request.setStartTime( new Date() );
initializeBuildContext( request );
EventDispatcher dispatcher = new DefaultEventDispatcher( request.getEventMonitors() ); EventDispatcher dispatcher = new DefaultEventDispatcher( request.getEventMonitors() );
String event = MavenEvents.REACTOR_EXECUTION; String event = MavenEvents.REACTOR_EXECUTION;
@ -166,6 +173,21 @@ public class DefaultMaven
return new DefaultMavenExecutionResult( result.getReactorManager() ); 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, private void logErrors( ReactorManager rm,
boolean showErrors ) boolean showErrors )
{ {
@ -304,17 +326,22 @@ public class DefaultMaven
throws MavenExecutionException, BuildFailureException throws MavenExecutionException, BuildFailureException
{ {
List projects; List projects;
List files;
try try
{ {
List files = getProjectFiles( request ); files = getProjectFiles( request );
projects = collectProjects( files, request.getLocalRepository(), request.isRecursive(),
request.getSettings(), globalProfileManager, !request.useReactor() );
} }
catch ( IOException e ) 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 ) catch ( ArtifactResolutionException e )
{ {

View File

@ -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 );
}
}

View File

@ -80,6 +80,10 @@
<role>org.apache.maven.Maven</role> <role>org.apache.maven.Maven</role>
<implementation>org.apache.maven.DefaultMaven</implementation> <implementation>org.apache.maven.DefaultMaven</implementation>
<requirements> <requirements>
<requirement>
<role>org.apache.maven.context.BuildContextManager</role>
<role-hint>default</role-hint>
</requirement>
<requirement> <requirement>
<role>org.apache.maven.project.MavenProjectBuilder</role> <role>org.apache.maven.project.MavenProjectBuilder</role>
</requirement> </requirement>

View File

@ -2629,6 +2629,16 @@
<type>ActivationFile</type> <type>ActivationFile</type>
</association> </association>
</field> </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> </fields>
</class> </class>
<class> <class>
@ -2714,6 +2724,32 @@
</field> </field>
</fields> </fields>
</class> </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 --> <!-- /BuildProfile support -->
<class xml.tagName="plugin"> <class xml.tagName="plugin">
<name>ReportPlugin</name> <name>ReportPlugin</name>

View File

@ -29,6 +29,11 @@
<description>This library is used to not only read Maven project object model files, but to assemble inheritence <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> and to retrieve remote models as required.</description>
<dependencies> <dependencies>
<dependency>
<groupId>org.apache.maven</groupId>
<artifactId>maven-build-context</artifactId>
<version>2.1-SNAPSHOT</version>
</dependency>
<dependency> <dependency>
<groupId>org.apache.maven</groupId> <groupId>org.apache.maven</groupId>
<artifactId>maven-artifact-test</artifactId> <artifactId>maven-artifact-test</artifactId>

View File

@ -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;
}
}

View File

@ -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;
}
}

View File

@ -1,5 +1,6 @@
package org.apache.maven.profiles.activation; package org.apache.maven.profiles.activation;
import org.apache.maven.context.BuildContextManager;
import org.apache.maven.model.Profile; import org.apache.maven.model.Profile;
/* /*
@ -21,6 +22,8 @@ import org.apache.maven.model.Profile;
public abstract class DetectedProfileActivator public abstract class DetectedProfileActivator
implements ProfileActivator implements ProfileActivator
{ {
private BuildContextManager buildContextManager;
public boolean canDetermineActivation( Profile profile ) public boolean canDetermineActivation( Profile profile )
{ {
return canDetectActivation( profile ); return canDetectActivation( profile );
@ -28,4 +31,9 @@ public abstract class DetectedProfileActivator
protected abstract boolean canDetectActivation( Profile profile ); protected abstract boolean canDetectActivation( Profile profile );
protected BuildContextManager getBuildContextManager()
{
return buildContextManager;
}
} }

View File

@ -22,9 +22,10 @@ import org.codehaus.plexus.util.FileUtils;
*/ */
public class FileProfileActivator 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; return profile.getActivation() != null && profile.getActivation().getFile() != null;
} }
@ -56,4 +57,5 @@ public class FileProfileActivator
return false; return false;
} }
} }

View File

@ -1,5 +1,6 @@
package org.apache.maven.profiles.activation; package org.apache.maven.profiles.activation;
import org.apache.maven.context.SystemBuildContext;
import org.apache.maven.model.Activation; import org.apache.maven.model.Activation;
import org.apache.maven.model.Profile; import org.apache.maven.model.Profile;
import org.codehaus.plexus.util.StringUtils; import org.codehaus.plexus.util.StringUtils;
@ -23,7 +24,8 @@ import org.codehaus.plexus.util.StringUtils;
public class JdkPrefixProfileActivator public class JdkPrefixProfileActivator
extends DetectedProfileActivator 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 ) public boolean isActive( Profile profile )
{ {
@ -39,8 +41,11 @@ public class JdkPrefixProfileActivator
jdk = jdk.substring( 1 ); 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. // 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 ) if ( reverse )
{ {

View File

@ -1,15 +1,12 @@
package org.apache.maven.profiles.activation; 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.Activation;
import org.apache.maven.model.ActivationProperty; import org.apache.maven.model.ActivationProperty;
import org.apache.maven.model.Profile; 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.LogEnabled;
import org.codehaus.plexus.logging.Logger; import org.codehaus.plexus.logging.Logger;
import org.codehaus.plexus.logging.console.ConsoleLogger; import org.codehaus.plexus.logging.console.ConsoleLogger;
import org.codehaus.plexus.personality.plexus.lifecycle.phase.Contextualizable;
import org.codehaus.plexus.util.StringUtils; import org.codehaus.plexus.util.StringUtils;
/* /*
@ -29,16 +26,11 @@ import org.codehaus.plexus.util.StringUtils;
*/ */
public class SystemPropertyProfileActivator public class SystemPropertyProfileActivator
extends DetectedProfileActivator implements Contextualizable, LogEnabled extends DetectedProfileActivator
implements LogEnabled
{ {
private Context context;
private Logger logger; private Logger logger;
public void contextualize(Context context) throws ContextException
{
this.context = context;
}
protected boolean canDetectActivation( Profile profile ) protected boolean canDetectActivation( Profile profile )
{ {
return profile.getActivation() != null && profile.getActivation().getProperty() != null; return profile.getActivation() != null && profile.getActivation().getProperty() != null;
@ -46,30 +38,14 @@ public class SystemPropertyProfileActivator
public boolean isActive( Profile profile ) 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(); Activation activation = profile.getActivation();
ActivationProperty property = activation.getProperty(); ActivationProperty property = activation.getProperty();
if ( property != null ) if ( property != null )
{ {
SystemBuildContext systemBuildContext = SystemBuildContext.getSystemBuildContext( getBuildContextManager(), true );
String name = property.getName(); String name = property.getName();
boolean reverseName = false; boolean reverseName = false;
@ -79,7 +55,7 @@ public class SystemPropertyProfileActivator
name = name.substring( 1 ); name = name.substring( 1 );
} }
String sysValue = properties != null ? properties.getProperty( name ) : null; String sysValue = systemBuildContext.getSystemProperty( name );
String propValue = property.getValue(); String propValue = property.getValue();
if ( StringUtils.isNotEmpty( propValue ) ) if ( StringUtils.isNotEmpty( propValue ) )

View File

@ -33,6 +33,7 @@ import org.apache.maven.artifact.resolver.ArtifactResolutionResult;
import org.apache.maven.artifact.resolver.ArtifactResolver; import org.apache.maven.artifact.resolver.ArtifactResolver;
import org.apache.maven.artifact.versioning.InvalidVersionSpecificationException; import org.apache.maven.artifact.versioning.InvalidVersionSpecificationException;
import org.apache.maven.artifact.versioning.VersionRange; import org.apache.maven.artifact.versioning.VersionRange;
import org.apache.maven.context.BuildContextManager;
import org.apache.maven.model.Build; import org.apache.maven.model.Build;
import org.apache.maven.model.Dependency; import org.apache.maven.model.Dependency;
import org.apache.maven.model.DependencyManagement; 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.Extension;
import org.apache.maven.model.Model; import org.apache.maven.model.Model;
import org.apache.maven.model.Plugin; import org.apache.maven.model.Plugin;
import org.apache.maven.model.Profile;
import org.apache.maven.model.ReportPlugin; import org.apache.maven.model.ReportPlugin;
import org.apache.maven.model.io.xpp3.MavenXpp3Reader; import org.apache.maven.model.io.xpp3.MavenXpp3Reader;
import org.apache.maven.profiles.DefaultProfileManager; import org.apache.maven.profiles.DefaultProfileManager;
import org.apache.maven.profiles.MavenProfilesBuilder; import org.apache.maven.profiles.MavenProfilesBuilder;
import org.apache.maven.profiles.ProfileManager; 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.profiles.activation.ProfileActivationException;
import org.apache.maven.project.artifact.InvalidDependencyVersionException; 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.DefaultModelLineage;
import org.apache.maven.project.build.model.ModelLineage; import org.apache.maven.project.build.model.ModelLineage;
import org.apache.maven.project.build.model.ModelLineageBuilder; import org.apache.maven.project.build.model.ModelLineageBuilder;
@ -150,8 +149,6 @@ public class DefaultMavenProjectBuilder
private ModelInheritanceAssembler modelInheritanceAssembler; private ModelInheritanceAssembler modelInheritanceAssembler;
private ProfileInjector profileInjector;
private ModelValidator validator; private ModelValidator validator;
private Map processedProjectCache = new HashMap(); private Map processedProjectCache = new HashMap();
@ -167,12 +164,12 @@ public class DefaultMavenProjectBuilder
private ModelInterpolator modelInterpolator; private ModelInterpolator modelInterpolator;
private ArtifactRepositoryFactory artifactRepositoryFactory;
private ModelLineageBuilder modelLineageBuilder; private ModelLineageBuilder modelLineageBuilder;
private ProfileAdvisor profileAdvisor; private ProfileAdvisor profileAdvisor;
private BuildContextManager buildContextManager;
private MavenTools mavenTools; private MavenTools mavenTools;
// ---------------------------------------------------------------------- // ----------------------------------------------------------------------
@ -263,18 +260,31 @@ public class DefaultMavenProjectBuilder
superModel.setVersion( STANDALONE_SUPERPOM_VERSION ); 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 ); 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 ); project.setOriginalModel( superModel );
@ -296,6 +306,7 @@ public class DefaultMavenProjectBuilder
} }
} }
public MavenProject buildWithDependencies( File projectDescriptor, public MavenProject buildWithDependencies( File projectDescriptor,
ArtifactRepository localRepository, ArtifactRepository localRepository,
ProfileManager profileManager ) ProfileManager profileManager )
@ -1001,6 +1012,11 @@ public class DefaultMavenProjectBuilder
modelLineageBuilder.resumeBuildingModelLineage( modelLineage, localRepository, externalProfileManager, cachedPomFilesByModelId ); modelLineageBuilder.resumeBuildingModelLineage( modelLineage, localRepository, externalProfileManager, cachedPomFilesByModelId );
ProjectBuildContext projectContext = ProjectBuildContext.getProjectBuildContext( buildContextManager, true );
projectContext.setModelLineage( modelLineage );
projectContext.store( buildContextManager );
List explicitlyActive; List explicitlyActive;
List explicitlyInactive; List explicitlyInactive;
@ -1027,6 +1043,9 @@ public class DefaultMavenProjectBuilder
MavenProject project = new MavenProject( currentModel ); MavenProject project = new MavenProject( currentModel );
project.setFile( currentPom ); project.setFile( currentPom );
projectContext.setCurrentProject( project );
projectContext.store( buildContextManager );
project.setActiveProfiles( profileAdvisor.applyActivatedProfiles( model, projectDir, explicitlyActive, project.setActiveProfiles( profileAdvisor.applyActivatedProfiles( model, projectDir, explicitlyActive,
explicitlyInactive ) ); explicitlyInactive ) );
@ -1061,80 +1080,6 @@ public class DefaultMavenProjectBuilder
return result; 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 ) private Model readModel( String projectId, File file, boolean strict )
throws ProjectBuildingException throws ProjectBuildingException
{ {

View File

@ -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 );
}
}

View File

@ -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;
}
};
}
} }

View File

@ -89,6 +89,14 @@ public interface ModelLineage
*/ */
List getArtifactRepositoryListsInDescendingOrder(); 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, * Iterate over the lineage of Model instances, starting with the child (current) Model,
* and ending with the deepest ancestor. * and ending with the deepest ancestor.

View File

@ -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();
}

View File

@ -101,9 +101,6 @@
<requirement> <requirement>
<role>org.apache.maven.profiles.MavenProfilesBuilder</role> <role>org.apache.maven.profiles.MavenProfilesBuilder</role>
</requirement> </requirement>
<requirement>
<role>org.apache.maven.project.injection.ProfileInjector</role>
</requirement>
<requirement> <requirement>
<role>org.apache.maven.project.injection.ModelDefaultsInjector</role> <role>org.apache.maven.project.injection.ModelDefaultsInjector</role>
</requirement> </requirement>
@ -126,7 +123,8 @@
<role>org.apache.maven.artifact.resolver.ArtifactResolver</role> <role>org.apache.maven.artifact.resolver.ArtifactResolver</role>
</requirement> </requirement>
<requirement> <requirement>
<role>org.apache.maven.artifact.repository.ArtifactRepositoryFactory</role> <role>org.apache.maven.context.BuildContextManager</role>
<role-hint>default</role-hint>
</requirement> </requirement>
<requirement> <requirement>
<role>org.apache.maven.artifact.manager.WagonManager</role> <role>org.apache.maven.artifact.manager.WagonManager</role>
@ -155,6 +153,12 @@
<role>org.apache.maven.profiles.activation.ProfileActivator</role> <role>org.apache.maven.profiles.activation.ProfileActivator</role>
<role-hint>jdk-prefix</role-hint> <role-hint>jdk-prefix</role-hint>
<implementation>org.apache.maven.profiles.activation.JdkPrefixProfileActivator</implementation> <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> </component>
<!-- <!--
| |
@ -165,6 +169,12 @@
<role>org.apache.maven.profiles.activation.ProfileActivator</role> <role>org.apache.maven.profiles.activation.ProfileActivator</role>
<role-hint>system-property</role-hint> <role-hint>system-property</role-hint>
<implementation>org.apache.maven.profiles.activation.SystemPropertyProfileActivator</implementation> <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> </component>
<!-- <!--
| |
@ -186,6 +196,16 @@
<role-hint>file</role-hint> <role-hint>file</role-hint>
<implementation>org.apache.maven.profiles.activation.FileProfileActivator</implementation> <implementation>org.apache.maven.profiles.activation.FileProfileActivator</implementation>
</component> </component>
<!--
|
|
|
-->
<component>
<role>org.apache.maven.profiles.activation.ProfileActivator</role>
<role-hint>custom</role-hint>
<implementation>org.apache.maven.profiles.activation.CustomActivator</implementation>
</component>
<!-- <!--
| |
| |

View File

@ -1,9 +1,12 @@
package org.apache.maven.profiles; 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.Activation;
import org.apache.maven.model.ActivationOS;
import org.apache.maven.model.ActivationProperty; import org.apache.maven.model.ActivationProperty;
import org.apache.maven.model.Profile; import org.apache.maven.model.Profile;
import org.apache.maven.model.ActivationOS;
import org.apache.maven.profiles.activation.ProfileActivationException; import org.apache.maven.profiles.activation.ProfileActivationException;
import org.codehaus.plexus.PlexusTestCase; import org.codehaus.plexus.PlexusTestCase;
@ -13,8 +16,20 @@ public class DefaultProfileManagerTest
extends PlexusTestCase 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 public void testShouldActivateDefaultProfile() throws ProfileActivationException
{ {
SystemBuildContext sysContext = SystemBuildContext.getSystemBuildContext( buildContextManager, true );
sysContext.store( buildContextManager );
Profile notActivated = new Profile(); Profile notActivated = new Profile();
notActivated.setId("notActivated"); notActivated.setId("notActivated");
@ -47,6 +62,9 @@ public class DefaultProfileManagerTest
public void testShouldNotActivateDefaultProfile() throws ProfileActivationException public void testShouldNotActivateDefaultProfile() throws ProfileActivationException
{ {
SystemBuildContext sysContext = SystemBuildContext.getSystemBuildContext( buildContextManager, true );
sysContext.store( buildContextManager );
Profile syspropActivated = new Profile(); Profile syspropActivated = new Profile();
syspropActivated.setId("syspropActivated"); syspropActivated.setId("syspropActivated");
@ -82,6 +100,9 @@ public class DefaultProfileManagerTest
public void testShouldNotActivateReversalOfPresentSystemProperty() throws ProfileActivationException public void testShouldNotActivateReversalOfPresentSystemProperty() throws ProfileActivationException
{ {
SystemBuildContext sysContext = SystemBuildContext.getSystemBuildContext( buildContextManager, true );
sysContext.store( buildContextManager );
Profile syspropActivated = new Profile(); Profile syspropActivated = new Profile();
syspropActivated.setId("syspropActivated"); syspropActivated.setId("syspropActivated");

View File

@ -1,21 +1,37 @@
package org.apache.maven.profiles.activation; 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.Activation;
import org.apache.maven.model.ActivationProperty; import org.apache.maven.model.ActivationProperty;
import org.apache.maven.model.Profile; import org.apache.maven.model.Profile;
import org.codehaus.plexus.PlexusTestCase;
import org.codehaus.plexus.context.ContextException; import org.codehaus.plexus.context.ContextException;
import org.codehaus.plexus.context.DefaultContext;
import java.util.Properties; import java.util.Properties;
import junit.framework.TestCase;
public class SystemPropertyProfileActivatorTest 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() public void testCanDetect_ShouldReturnTrueWhenActivationPropertyIsPresent()
throws ContextException throws Exception
{ {
ActivationProperty prop = new ActivationProperty(); ActivationProperty prop = new ActivationProperty();
prop.setName( "test" ); prop.setName( "test" );
@ -28,11 +44,11 @@ public class SystemPropertyProfileActivatorTest
profile.setActivation( activation ); profile.setActivation( activation );
assertTrue( buildProfileActivator().canDetermineActivation( profile ) ); assertTrue( activator.canDetermineActivation( profile ) );
} }
public void testCanDetect_ShouldReturnFalseWhenActivationPropertyIsNotPresent() public void testCanDetect_ShouldReturnFalseWhenActivationPropertyIsNotPresent()
throws ContextException throws Exception
{ {
Activation activation = new Activation(); Activation activation = new Activation();
@ -40,11 +56,11 @@ public class SystemPropertyProfileActivatorTest
profile.setActivation( activation ); profile.setActivation( activation );
assertFalse( buildProfileActivator().canDetermineActivation( profile ) ); assertFalse( activator.canDetermineActivation( profile ) );
} }
public void testIsActive_ShouldReturnTrueWhenPropertyNameSpecifiedAndPresent() public void testIsActive_ShouldReturnTrueWhenPropertyNameSpecifiedAndPresent()
throws ContextException throws Exception
{ {
ActivationProperty prop = new ActivationProperty(); ActivationProperty prop = new ActivationProperty();
prop.setName( "test" ); prop.setName( "test" );
@ -59,11 +75,11 @@ public class SystemPropertyProfileActivatorTest
System.setProperty( "test", "true" ); System.setProperty( "test", "true" );
assertTrue( buildProfileActivator().isActive( profile ) ); assertTrue( activator.isActive( profile ) );
} }
public void testIsActive_ShouldReturnFalseWhenPropertyNameSpecifiedAndMissing() public void testIsActive_ShouldReturnFalseWhenPropertyNameSpecifiedAndMissing()
throws ContextException throws Exception
{ {
ActivationProperty prop = new ActivationProperty(); ActivationProperty prop = new ActivationProperty();
prop.setName( "test" ); prop.setName( "test" );
@ -80,16 +96,7 @@ public class SystemPropertyProfileActivatorTest
props.remove( "test" ); props.remove( "test" );
System.setProperties( props ); System.setProperties( props );
assertFalse( buildProfileActivator().isActive( profile ) ); assertFalse( activator.isActive( profile ) );
}
private SystemPropertyProfileActivator buildProfileActivator()
throws ContextException
{
SystemPropertyProfileActivator activator = new SystemPropertyProfileActivator();
activator.contextualize( new DefaultContext() );
return activator;
} }
} }

View File

@ -71,6 +71,54 @@ public abstract class AbstractModelLineageTest
assertEquals( 1, ml.size() ); 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() public void testModelIterator_ShouldAddTwoModelsAndIterateInFIFOOrder()
{ {
ModelLineage ml = newModelLineage(); ModelLineage ml = newModelLineage();

View File

@ -19,6 +19,23 @@
<role-hint>test</role-hint> <role-hint>test</role-hint>
<implementation>org.apache.maven.project.injection.TestProfileInjector</implementation> <implementation>org.apache.maven.project.injection.TestProfileInjector</implementation>
</component> </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> <component>
<role>org.apache.maven.project.TestArtifactResolver</role> <role>org.apache.maven.project.TestArtifactResolver</role>
<implementation>org.apache.maven.project.TestArtifactResolver</implementation> <implementation>org.apache.maven.project.TestArtifactResolver</implementation>
@ -56,10 +73,6 @@
<requirement> <requirement>
<role>org.apache.maven.project.injection.ModelDefaultsInjector</role> <role>org.apache.maven.project.injection.ModelDefaultsInjector</role>
</requirement> </requirement>
<requirement>
<role>org.apache.maven.project.injection.ProfileInjector</role>
<role-hint>test</role-hint>
</requirement>
<requirement> <requirement>
<role>org.apache.maven.project.interpolation.ModelInterpolator</role> <role>org.apache.maven.project.interpolation.ModelInterpolator</role>
</requirement> </requirement>
@ -79,7 +92,8 @@
<role>org.apache.maven.artifact.resolver.ArtifactResolver</role> <role>org.apache.maven.artifact.resolver.ArtifactResolver</role>
</requirement> </requirement>
<requirement> <requirement>
<role>org.apache.maven.artifact.repository.ArtifactRepositoryFactory</role> <role>org.apache.maven.context.BuildContextManager</role>
<role-hint>default</role-hint>
</requirement> </requirement>
<requirement> <requirement>
<role>org.apache.maven.MavenTools</role> <role>org.apache.maven.MavenTools</role>

View File

@ -37,6 +37,23 @@
</requirement> </requirement>
</requirements> </requirements>
</component> </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> <component>
<role>org.apache.maven.project.MavenProjectBuilder</role> <role>org.apache.maven.project.MavenProjectBuilder</role>
<role-hint>test</role-hint> <role-hint>test</role-hint>
@ -56,10 +73,6 @@
<requirement> <requirement>
<role>org.apache.maven.project.injection.ModelDefaultsInjector</role> <role>org.apache.maven.project.injection.ModelDefaultsInjector</role>
</requirement> </requirement>
<requirement>
<role>org.apache.maven.project.injection.ProfileInjector</role>
<role-hint>test</role-hint>
</requirement>
<requirement> <requirement>
<role>org.apache.maven.project.interpolation.ModelInterpolator</role> <role>org.apache.maven.project.interpolation.ModelInterpolator</role>
</requirement> </requirement>
@ -79,10 +92,11 @@
<role>org.apache.maven.artifact.resolver.ArtifactResolver</role> <role>org.apache.maven.artifact.resolver.ArtifactResolver</role>
</requirement> </requirement>
<requirement> <requirement>
<role>org.apache.maven.artifact.repository.ArtifactRepositoryFactory</role> <role>org.apache.maven.MavenTools</role>
</requirement> </requirement>
<requirement> <requirement>
<role>org.apache.maven.MavenTools</role> <role>org.apache.maven.context.BuildContextManager</role>
<role-hint>default</role-hint>
</requirement> </requirement>
</requirements> </requirements>
</component> </component>

View File

@ -1,5 +1,4 @@
<?xml version="1.0" encoding="UTF-8"?> <?xml version="1.0" encoding="UTF-8"?>
<!-- <!--
~ Copyright 2005-2006 The Apache Software Foundation. ~ Copyright 2005-2006 The Apache Software Foundation.
~ ~
@ -149,6 +148,7 @@
<module>maven-artifact</module> <module>maven-artifact</module>
<module>maven-artifact-manager</module> <module>maven-artifact-manager</module>
<module>maven-artifact-test</module> <module>maven-artifact-test</module>
<module>maven-build-context</module>
<module>maven-core</module> <module>maven-core</module>
<module>maven-error-diagnostics</module> <module>maven-error-diagnostics</module>
<module>maven-model</module> <module>maven-model</module>