You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@maven.apache.org by be...@apache.org on 2008/12/29 11:41:47 UTC
svn commit: r729856 - in
/maven/core-integration-testing/trunk/core-it-suite/src/test:
java/org/apache/maven/it/ resources/mng-3933/
Author: bentmann
Date: Mon Dec 29 02:41:46 2008
New Revision: 729856
URL: http://svn.apache.org/viewvc?rev=729856&view=rev
Log:
o Extended IT to test other profile activators, too
Added:
maven/core-integration-testing/trunk/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng3933ProfilesXmlActivationTest.java
- copied, changed from r729841, maven/core-integration-testing/trunk/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng3933OsTriggeredExternalProfileTest.java
Removed:
maven/core-integration-testing/trunk/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng3933OsTriggeredExternalProfileTest.java
Modified:
maven/core-integration-testing/trunk/core-it-suite/src/test/java/org/apache/maven/it/IntegrationTestSuite.java
maven/core-integration-testing/trunk/core-it-suite/src/test/resources/mng-3933/profiles.xml
Modified: maven/core-integration-testing/trunk/core-it-suite/src/test/java/org/apache/maven/it/IntegrationTestSuite.java
URL: http://svn.apache.org/viewvc/maven/core-integration-testing/trunk/core-it-suite/src/test/java/org/apache/maven/it/IntegrationTestSuite.java?rev=729856&r1=729855&r2=729856&view=diff
==============================================================================
--- maven/core-integration-testing/trunk/core-it-suite/src/test/java/org/apache/maven/it/IntegrationTestSuite.java (original)
+++ maven/core-integration-testing/trunk/core-it-suite/src/test/java/org/apache/maven/it/IntegrationTestSuite.java Mon Dec 29 02:41:46 2008
@@ -95,7 +95,7 @@
suite.addTestSuite( MavenITmng3940EnvVarInterpolationTest.class );
suite.addTestSuite( MavenITmng3938MergePluginExecutionsTest.class );
suite.addTestSuite( MavenITmng3937MergedPluginExecutionGoalsTest.class );
- suite.addTestSuite( MavenITmng3933OsTriggeredExternalProfileTest.class );
+ suite.addTestSuite( MavenITmng3933ProfilesXmlActivationTest.class );
suite.addTestSuite( MavenITmng3927PluginDefaultExecutionConfigTest.class );
suite.addTestSuite( MavenITmng3925MergedPluginExecutionOrderTest.class );
suite.addTestSuite( MavenITmng3924XmlMarkupInterpolationTest.class );
Copied: maven/core-integration-testing/trunk/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng3933ProfilesXmlActivationTest.java (from r729841, maven/core-integration-testing/trunk/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng3933OsTriggeredExternalProfileTest.java)
URL: http://svn.apache.org/viewvc/maven/core-integration-testing/trunk/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng3933ProfilesXmlActivationTest.java?p2=maven/core-integration-testing/trunk/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng3933ProfilesXmlActivationTest.java&p1=maven/core-integration-testing/trunk/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng3933OsTriggeredExternalProfileTest.java&r1=729841&r2=729856&rev=729856&view=diff
==============================================================================
--- maven/core-integration-testing/trunk/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng3933OsTriggeredExternalProfileTest.java (original)
+++ maven/core-integration-testing/trunk/core-it-suite/src/test/java/org/apache/maven/it/MavenITmng3933ProfilesXmlActivationTest.java Mon Dec 29 02:41:46 2008
@@ -24,6 +24,7 @@
import org.apache.maven.it.util.Os;
import java.io.File;
+import java.util.Collections;
import java.util.Properties;
/**
@@ -32,17 +33,17 @@
* @author Benjamin Bentmann
* @version $Id$
*/
-public class MavenITmng3933OsTriggeredExternalProfileTest
+public class MavenITmng3933ProfilesXmlActivationTest
extends AbstractMavenIntegrationTestCase
{
- public MavenITmng3933OsTriggeredExternalProfileTest()
+ public MavenITmng3933ProfilesXmlActivationTest()
{
- super( "(2.0.10,2.1.0-M1),(2.1.0-M1,)" );
}
/**
- * Test that OS-triggered profiles from an external profiles.xml are activated.
+ * Test that profiles from an external profiles.xml are properly activated. This is really a different story
+ * than profiles in the settings.xml or the POM.
*/
public void testitMNG3933()
throws Exception
@@ -52,21 +53,45 @@
Verifier verifier = new Verifier( testDir.getAbsolutePath() );
verifier.setAutoclean( false );
verifier.deleteDirectory( "target" );
- verifier.executeGoal( "validate" );
+ verifier.getSystemProperties().setProperty( "maven.profile.activator", "test" );
+ verifier.executeGoal( "validate", Collections.singletonMap( "MAVEN_PROFILE", "test" ) );
verifier.verifyErrorFreeLog();
verifier.resetStreams();
Properties props = verifier.loadProperties( "target/profile.properties" );
- if ( Os.isFamily( Os.FAMILY_WINDOWS ) || Os.isFamily( Os.FAMILY_MAC ) || Os.isFamily( Os.FAMILY_UNIX ) )
+
+ assertEquals( "DEFAULT-ACTIVATION", props.getProperty( "project.properties.defaultProperty" ) );
+
+ assertEquals( "SYS-PROP-ACTIVATION", props.getProperty( "project.properties.sysProperty" ) );
+
+ if ( matchesVersionRange( "(2.0.8,)" ) )
{
- assertEquals( "PASSED", props.getProperty( "project.properties.profileProperty" ) );
+ // MNG-2848
+ assertEquals( "ENV-PROP-ACTIVATION", props.getProperty( "project.properties.envProperty" ) );
}
- else
+
+ assertEquals( "MISSING-FILE-ACTIVATION", props.getProperty( "project.properties.fileProperty" ) );
+
+ assertEquals( "JDK-ACTIVATION", props.getProperty( "project.properties.jdkProperty" ) );
+
+ if ( matchesVersionRange( "(2.0.10,2.1.0-M1),(2.1.0-M1,)" ) )
{
- System.out.println();
- System.out.println( "[WARNING] Skipping test on unrecognized OS: " + Os.OS_NAME );
- System.out.println();
+ // MNG-3933
+ if ( Os.isFamily( Os.FAMILY_WINDOWS ) || Os.isFamily( Os.FAMILY_MAC ) || Os.isFamily( Os.FAMILY_UNIX ) )
+ {
+ assertEquals( "OS-FAMILY-ACTIVATION", props.getProperty( "project.properties.osFamilyProperty" ) );
+ }
+ else
+ {
+ System.out.println();
+ System.out.println( "[WARNING] Skipping OS activation test on unrecognized OS: " + Os.OS_NAME );
+ System.out.println();
+ }
}
+
+ assertEquals( null, props.getProperty( "project.properties.sysPropertyMissing" ) );
+ assertEquals( null, props.getProperty( "project.properties.envPropertyMissing" ) );
+ assertEquals( null, props.getProperty( "project.properties.filePropertyMissing" ) );
}
}
Modified: maven/core-integration-testing/trunk/core-it-suite/src/test/resources/mng-3933/profiles.xml
URL: http://svn.apache.org/viewvc/maven/core-integration-testing/trunk/core-it-suite/src/test/resources/mng-3933/profiles.xml?rev=729856&r1=729855&r2=729856&view=diff
==============================================================================
--- maven/core-integration-testing/trunk/core-it-suite/src/test/resources/mng-3933/profiles.xml (original)
+++ maven/core-integration-testing/trunk/core-it-suite/src/test/resources/mng-3933/profiles.xml Mon Dec 29 02:41:46 2008
@@ -20,38 +20,153 @@
-->
<profilesXml>
+ <activeProfiles>
+ <activeProfile>profile-default</activeProfile>
+ </activeProfiles>
<profiles>
+ <!-- check activation by default -->
<profile>
- <id>PROFILE-A</id>
+ <id>profile-default</id>
+ <properties>
+ <defaultProperty>DEFAULT-ACTIVATION</defaultProperty>
+ </properties>
+ </profile>
+
+ <!-- check activation by OS family -->
+ <profile>
+ <id>profile-os-a</id>
<activation>
<os>
<family>winDOWS</family>
</os>
</activation>
<properties>
- <profileProperty>PASSED</profileProperty>
+ <osFamilyProperty>OS-FAMILY-ACTIVATION</osFamilyProperty>
</properties>
</profile>
<profile>
- <id>PROFILE-B</id>
+ <id>profile-os-b</id>
<activation>
<os>
<family>unIX</family>
</os>
</activation>
<properties>
- <profileProperty>PASSED</profileProperty>
+ <osFamilyProperty>OS-FAMILY-ACTIVATION</osFamilyProperty>
</properties>
</profile>
<profile>
- <id>PROFILE-C</id>
+ <id>profile-os-c</id>
<activation>
<os>
<family>mAC</family>
</os>
</activation>
<properties>
- <profileProperty>PASSED</profileProperty>
+ <osFamilyProperty>OS-FAMILY-ACTIVATION</osFamilyProperty>
+ </properties>
+ </profile>
+
+ <!-- check activation by JDK version -->
+ <profile>
+ <id>profile-jdk</id>
+ <activation>
+ <jdk>!1.0</jdk>
+ </activation>
+ <properties>
+ <jdkProperty>JDK-ACTIVATION</jdkProperty>
+ </properties>
+ </profile>
+
+ <!-- check non-activation by JDK version -->
+ <profile>
+ <id>profile-jdk-inactive</id>
+ <activation>
+ <jdk>1.0.0.0</jdk>
+ </activation>
+ <properties>
+ <jdkPropertyMissing>JDK-ACTIVATION</jdkPropertyMissing>
+ </properties>
+ </profile>
+
+ <!-- check activation by ordinary system property -->
+ <profile>
+ <id>profile-sys-prop</id>
+ <activation>
+ <property>
+ <name>maven.profile.activator</name>
+ <value>test</value>
+ </property>
+ </activation>
+ <properties>
+ <sysProperty>SYS-PROP-ACTIVATION</sysProperty>
+ </properties>
+ </profile>
+
+ <!-- check non-activation by absent system property -->
+ <profile>
+ <id>profile-sys-prop-inactive</id>
+ <activation>
+ <property>
+ <name>maven.profile.inactive</name>
+ </property>
+ </activation>
+ <properties>
+ <sysPropertyMissing>SYS-PROP-ACTIVATION</sysPropertyMissing>
+ </properties>
+ </profile>
+
+ <!-- check activation by environment variable -->
+ <profile>
+ <id>profile-env-prop</id>
+ <activation>
+ <property>
+ <name>env.MAVEN_PROFILE</name>
+ <value>test</value>
+ </property>
+ </activation>
+ <properties>
+ <envProperty>ENV-PROP-ACTIVATION</envProperty>
+ </properties>
+ </profile>
+
+ <!-- check non-activation by environment variable -->
+ <profile>
+ <id>profile-env-prop-inactive</id>
+ <activation>
+ <property>
+ <name>env.MAVEN_CORE_IT</name>
+ <value>missing</value>
+ </property>
+ </activation>
+ <properties>
+ <envPropertyMissing>ENV-PROP-ACTIVATION</envPropertyMissing>
+ </properties>
+ </profile>
+
+ <!-- check activation by missing file -->
+ <profile>
+ <id>profile-file-missing</id>
+ <activation>
+ <file>
+ <missing>a-funky-file-name-that-most-likely-does-not-exist-on-an-ordinary-box</missing>
+ </file>
+ </activation>
+ <properties>
+ <fileProperty>MISSING-FILE-ACTIVATION</fileProperty>
+ </properties>
+ </profile>
+
+ <!-- check non-activation by missing file -->
+ <profile>
+ <id>profile-file-missing-inactive</id>
+ <activation>
+ <file>
+ <exists>a-funky-file-name-that-most-likely-does-not-exist-on-an-ordinary-box</exists>
+ </file>
+ </activation>
+ <properties>
+ <filePropertyMissing>MISSING-FILE-ACTIVATION</filePropertyMissing>
</properties>
</profile>
</profiles>