You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@maven.apache.org by st...@apache.org on 2012/01/03 17:41:49 UTC

svn commit: r1226858 - /maven/maven-3/trunk/maven-core/src/test/java/org/apache/maven/settings/SettingsUtilsTest.java

Author: stephenc
Date: Tue Jan  3 16:41:49 2012
New Revision: 1226858

URL: http://svn.apache.org/viewvc?rev=1226858&view=rev
Log:
[MNG-5224] REGRESSION: Injected Settings in a Mojo are missing the profiles from settings.xml

o Some unit tests to cover some of the fix.

Modified:
    maven/maven-3/trunk/maven-core/src/test/java/org/apache/maven/settings/SettingsUtilsTest.java

Modified: maven/maven-3/trunk/maven-core/src/test/java/org/apache/maven/settings/SettingsUtilsTest.java
URL: http://svn.apache.org/viewvc/maven/maven-3/trunk/maven-core/src/test/java/org/apache/maven/settings/SettingsUtilsTest.java?rev=1226858&r1=1226857&r2=1226858&view=diff
==============================================================================
--- maven/maven-3/trunk/maven-core/src/test/java/org/apache/maven/settings/SettingsUtilsTest.java (original)
+++ maven/maven-3/trunk/maven-core/src/test/java/org/apache/maven/settings/SettingsUtilsTest.java Tue Jan  3 16:41:49 2012
@@ -19,10 +19,13 @@ package org.apache.maven.settings;
  * under the License.
  */
 
-import java.util.List;
-
 import junit.framework.TestCase;
 
+import java.util.ArrayList;
+import java.util.List;
+import java.util.Properties;
+import java.util.Random;
+
 public class SettingsUtilsTest
     extends TestCase
 {
@@ -47,4 +50,77 @@ public class SettingsUtilsTest
         assertEquals( "org.codehaus.plexus", pluginGroups.get( 2 ) );
     }
 
+    public void testRoundTripProfiles()
+    {
+        Random entropy = new Random();
+        Profile p = new Profile();
+        p.setId( "id" + Long.toHexString( entropy.nextLong() ) );
+        Activation a = new Activation();
+        a.setActiveByDefault( entropy.nextBoolean() );
+        a.setJdk( "jdk" + Long.toHexString( entropy.nextLong() ) );
+        ActivationFile af = new ActivationFile();
+        af.setExists( "exists" + Long.toHexString( entropy.nextLong() ) );
+        af.setMissing( "missing" + Long.toHexString( entropy.nextLong() ) );
+        a.setFile( af );
+        ActivationProperty ap = new ActivationProperty();
+        ap.setName( "name" + Long.toHexString( entropy.nextLong() ) );
+        ap.setValue( "value" + Long.toHexString( entropy.nextLong() ) );
+        a.setProperty( ap );
+        ActivationOS ao = new ActivationOS();
+        ao.setArch( "arch" + Long.toHexString( entropy.nextLong() ) );
+        ao.setFamily( "family" + Long.toHexString( entropy.nextLong() ) );
+        ao.setName( "name" + Long.toHexString( entropy.nextLong() ) );
+        ao.setVersion( "version" + Long.toHexString( entropy.nextLong() ) );
+        a.setOs( ao );
+        p.setActivation( a );
+        Properties props = new Properties();
+        int count = entropy.nextInt( 10 );
+        for ( int i = 0; i < count; i++ )
+        {
+            props.setProperty( "name" + Long.toHexString( entropy.nextLong() ),
+                               "value" + Long.toHexString( entropy.nextLong() ) );
+        }
+        p.setProperties( props );
+        count = entropy.nextInt( 3 );
+        List<Repository> repos = new ArrayList<Repository>();
+        for ( int i = 0; i < count; i++ )
+        {
+            Repository r = new Repository();
+            r.setId( "id" + Long.toHexString( entropy.nextLong() ) );
+            r.setName( "name" + Long.toHexString( entropy.nextLong() ) );
+            r.setUrl( "url" + Long.toHexString( entropy.nextLong() ) );
+            repos.add( r );
+        }
+        p.setRepositories( repos );
+        count = entropy.nextInt( 3 );
+        repos = new ArrayList<Repository>();
+        for ( int i = 0; i < count; i++ )
+        {
+            Repository r = new Repository();
+            r.setId( "id" + Long.toHexString( entropy.nextLong() ) );
+            r.setName( "name" + Long.toHexString( entropy.nextLong() ) );
+            r.setUrl( "url" + Long.toHexString( entropy.nextLong() ) );
+            repos.add( r );
+        }
+        p.setPluginRepositories( repos );
+
+        Profile clone = SettingsUtils.convertToSettingsProfile( SettingsUtils.convertFromSettingsProfile( p ) );
+
+        assertEquals( p.getId(), clone.getId() );
+        assertEquals( p.getActivation().getJdk(), clone.getActivation().getJdk() );
+        assertEquals( p.getActivation().getFile().getExists(), clone.getActivation().getFile().getExists() );
+        assertEquals( p.getActivation().getFile().getMissing(), clone.getActivation().getFile().getMissing() );
+        assertEquals( p.getActivation().getProperty().getName(), clone.getActivation().getProperty().getName() );
+        assertEquals( p.getActivation().getProperty().getValue(), clone.getActivation().getProperty().getValue() );
+        assertEquals( p.getActivation().getOs().getArch(), clone.getActivation().getOs().getArch() );
+        assertEquals( p.getActivation().getOs().getFamily(), clone.getActivation().getOs().getFamily() );
+        assertEquals( p.getActivation().getOs().getName(), clone.getActivation().getOs().getName() );
+        assertEquals( p.getActivation().getOs().getVersion(), clone.getActivation().getOs().getVersion() );
+        assertEquals( p.getProperties(), clone.getProperties() );
+        assertEquals( p.getRepositories().size(), clone.getRepositories().size() );
+        // TODO deep compare the lists
+        assertEquals( p.getPluginRepositories().size(), clone.getPluginRepositories().size() );
+        // TODO deep compare the lists
+    }
+
 }