aboutsummaryrefslogtreecommitdiffstats
path: root/framework/src/maven/apache-maven-3.3.3/maven-core/src/test/java/org/apache/maven/settings/SettingsUtilsTest.java
diff options
context:
space:
mode:
Diffstat (limited to 'framework/src/maven/apache-maven-3.3.3/maven-core/src/test/java/org/apache/maven/settings/SettingsUtilsTest.java')
-rw-r--r--framework/src/maven/apache-maven-3.3.3/maven-core/src/test/java/org/apache/maven/settings/SettingsUtilsTest.java126
1 files changed, 126 insertions, 0 deletions
diff --git a/framework/src/maven/apache-maven-3.3.3/maven-core/src/test/java/org/apache/maven/settings/SettingsUtilsTest.java b/framework/src/maven/apache-maven-3.3.3/maven-core/src/test/java/org/apache/maven/settings/SettingsUtilsTest.java
new file mode 100644
index 00000000..f2231b3f
--- /dev/null
+++ b/framework/src/maven/apache-maven-3.3.3/maven-core/src/test/java/org/apache/maven/settings/SettingsUtilsTest.java
@@ -0,0 +1,126 @@
+package org.apache.maven.settings;
+
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements. See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership. The ASF licenses this file
+ * to you 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.
+ */
+
+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
+{
+
+ public void testShouldAppendRecessivePluginGroupIds()
+ {
+ Settings dominant = new Settings();
+ dominant.addPluginGroup( "org.apache.maven.plugins" );
+ dominant.addPluginGroup( "org.codehaus.modello" );
+
+ Settings recessive = new Settings();
+ recessive.addPluginGroup( "org.codehaus.plexus" );
+
+ SettingsUtils.merge( dominant, recessive, Settings.GLOBAL_LEVEL );
+
+ List<String> pluginGroups = dominant.getPluginGroups();
+
+ assertNotNull( pluginGroups );
+ assertEquals( 3, pluginGroups.size() );
+ assertEquals( "org.apache.maven.plugins", pluginGroups.get( 0 ) );
+ assertEquals( "org.codehaus.modello", pluginGroups.get( 1 ) );
+ 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
+ }
+
+}