Author: hboutemy
Date: Sun Dec 14 12:45:28 2008
New Revision: 726529

URL: http://svn.apache.org/viewvc?rev=726529&view=rev
Log:
copied unit-tests from maven-artifact

Added:
    
maven/mercury/trunk/mercury-artifact/src/test/java/org/apache/maven/mercury/artifact/version/ComparableVersionTest.java
   (with props)
    
maven/mercury/trunk/mercury-artifact/src/test/java/org/apache/maven/mercury/artifact/version/DefaultArtifactVersionTest.java
   (with props)

Added: 
maven/mercury/trunk/mercury-artifact/src/test/java/org/apache/maven/mercury/artifact/version/ComparableVersionTest.java
URL: 
http://svn.apache.org/viewvc/maven/mercury/trunk/mercury-artifact/src/test/java/org/apache/maven/mercury/artifact/version/ComparableVersionTest.java?rev=726529&view=auto
==============================================================================
--- 
maven/mercury/trunk/mercury-artifact/src/test/java/org/apache/maven/mercury/artifact/version/ComparableVersionTest.java
 (added)
+++ 
maven/mercury/trunk/mercury-artifact/src/test/java/org/apache/maven/mercury/artifact/version/ComparableVersionTest.java
 Sun Dec 14 12:45:28 2008
@@ -0,0 +1,183 @@
+package org.apache.maven.mercury.artifact.version;
+
+/*
+ * 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 java.util.Locale;
+
+import junit.framework.TestCase;
+
+/**
+ * Test ComparableVersion.
+ * 
+ * @author <a href="mailto:hbout...@apache.org";>Herve Boutemy</a>
+ * @version $Id$
+ */
+public class ComparableVersionTest
+    extends TestCase
+{
+    private Comparable newComparable( String version )
+    {
+        return new ComparableVersion( version );
+    }
+
+    private static final String[] VERSIONS_QUALIFIER =
+        { "1-SNAPSHOT", "1-alpha2snapshot", "1-alpha2", "1-alpha-123", 
"1-beta-2", "1-beta123", "1-m2", "1-m11",
+            "1-rc", "1-cr2", "1-rc123", "1", "1-sp", "1-sp2", "1-sp123", 
"1-abc", "1-def", "1-pom-1", "1-1-snapshot",
+            "1-1", "1-2", "1-123" };
+
+    private static final String[] VERSIONS_NUMBER =
+        { "2.0", "2-1", "2.0.a", "2.0.0.a", "2.0.2", "2.0.123", "2.1.0", 
"2.1-a", "2.1b", "2.1-c", "2.1-1", "2.1.0.1",
+            "2.2", "2.123", "11.a2", "11.a11", "11.b2", "11.b11", "11.m2", 
"11.m11", "11", "11.a", "11b", "11c", "11m" };
+
+    private void checkVersionsOrder( String[] versions )
+    {
+        Comparable[] c = new Comparable[versions.length];
+        for ( int i = 0; i < versions.length; i++ )
+        {
+            c[i] = newComparable( versions[i] );
+        }
+
+        for ( int i = 1; i < versions.length; i++ )
+        {
+            Comparable low = c[i - 1];
+            for ( int j = i; j < versions.length; j++ )
+            {
+                Comparable high = c[j];
+                assertTrue( "expected " + low + " < " + high, low.compareTo( 
high ) < 0 );
+                assertTrue( "expected " + high + " > " + low, high.compareTo( 
low ) > 0 );
+            }
+        }
+    }
+
+    private void checkVersionsEqual( String v1, String v2 )
+    {
+        Comparable c1 = newComparable( v1 );
+        Comparable c2 = newComparable( v2 );
+        assertTrue( "expected " + v1 + " == " + v2, c1.compareTo( c2 ) == 0 );
+        assertTrue( "expected " + v2 + " == " + v1, c2.compareTo( c1 ) == 0 );
+        assertTrue( "expected same hashcode for " + v1 + " and " + v2, 
c1.hashCode() == c2.hashCode() );
+        assertTrue( "expected " + v1 + ".equals( " + v2 + " )", c1.equals( c2 
) );
+        assertTrue( "expected " + v2 + ".equals( " + v1 + " )", c2.equals( c1 
) );
+    }
+
+    private void checkVersionsOrder( String v1, String v2 )
+    {
+        Comparable c1 = newComparable( v1 );
+        Comparable c2 = newComparable( v2 );
+        assertTrue( "expected " + v1 + " < " + v2, c1.compareTo( c2 ) < 0 );
+        assertTrue( "expected " + v2 + " > " + v1, c2.compareTo( c1 ) > 0 );
+    }
+
+    public void testVersionsQualifier()
+    {
+        checkVersionsOrder( VERSIONS_QUALIFIER );
+    }
+
+    public void testVersionsNumber()
+    {
+        checkVersionsOrder( VERSIONS_NUMBER );
+    }
+
+    public void testVersionsEqual()
+    {
+        checkVersionsEqual( "1", "1" );
+        checkVersionsEqual( "1", "1.0" );
+        checkVersionsEqual( "1", "1.0.0" );
+        checkVersionsEqual( "1.0", "1.0.0" );
+        checkVersionsEqual( "1", "1-0" );
+        checkVersionsEqual( "1", "1.0-0" );
+        checkVersionsEqual( "1.0", "1.0-0" );
+        checkVersionsEqual( "1a", "1.a" );
+        checkVersionsEqual( "1a", "1-a" );
+        checkVersionsEqual( "1a", "1.0-a" );
+        checkVersionsEqual( "1a", "1.0.0-a" );
+        checkVersionsEqual( "1.0a", "1.0.a" );
+        checkVersionsEqual( "1.0.0a", "1.0.0.a" );
+
+        // aliases
+        checkVersionsEqual( "1ga", "1" );
+        checkVersionsEqual( "1final", "1" );
+        checkVersionsEqual( "1cr", "1rc" );
+
+        // special "aliases" a, b and m for alpha, beta and milestone
+        checkVersionsEqual( "1a1", "1alpha1" );
+        checkVersionsEqual( "1b2", "1beta2" );
+        checkVersionsEqual( "1m3", "1milestone3" );
+    }
+
+    public void testVersionComparing()
+    {
+        checkVersionsOrder( "1", "2" );
+        checkVersionsOrder( "1.5", "2" );
+        checkVersionsOrder( "1", "2.5" );
+        checkVersionsOrder( "1.0", "1.1" );
+        checkVersionsOrder( "1.1", "1.2" );
+        checkVersionsOrder( "1.0.0", "1.1" );
+        checkVersionsOrder( "1.0.1", "1.1" );
+        checkVersionsOrder( "1.1", "1.2.0" );
+
+        checkVersionsOrder( "1.0-alpha-1", "1.0" );
+        checkVersionsOrder( "1.0-alpha-1", "1.0-alpha-2" );
+        checkVersionsOrder( "1.0-alpha-1", "1.0-beta-1" );
+
+        checkVersionsOrder( "1.0-SNAPSHOT", "1.0-beta-1" );
+        checkVersionsOrder( "1.0-SNAPSHOT", "1.0" );
+        checkVersionsOrder( "1.0-alpha-1-SNAPSHOT", "1.0-alpha-1" );
+
+        checkVersionsOrder( "1.0", "1.0-1" );
+        checkVersionsOrder( "1.0-1", "1.0-2" );
+        checkVersionsOrder( "1.0.0", "1.0-1" );
+
+        checkVersionsOrder( "2.0-1", "2.0.1" );
+        checkVersionsOrder( "2.0.1-klm", "2.0.1-lmn" );
+        checkVersionsOrder( "2.0.1", "2.0.1-xyz" );
+
+        checkVersionsOrder( "2.0.1", "2.0.1-123" );
+        checkVersionsOrder( "2.0.1-xyz", "2.0.1-123" );
+    }
+
+    public void testLocaleIndependent()
+    {
+        Locale orig = Locale.getDefault();
+        Locale[] locales = { Locale.ENGLISH, new Locale( "tr" ), 
Locale.getDefault() };
+        try
+        {
+            for ( Locale locale : locales )
+            {
+                Locale.setDefault( locale );
+                checkVersionsEqual( "1-abcdefghijklmnopqrstuvwxyz", 
"1-ABCDEFGHIJKLMNOPQRSTUVWXYZ" );
+            }
+        }
+        finally
+        {
+            Locale.setDefault( orig );
+        }
+    }
+
+    public void testReuse()
+    {
+        ComparableVersion c1 = new ComparableVersion( "1" );
+        c1.parseVersion( "2" );
+
+        Comparable c2 = newComparable( "2" );
+
+        assertEquals( "reused instance should be equivalent to new instance", 
c1, c2 );
+    }
+}

Propchange: 
maven/mercury/trunk/mercury-artifact/src/test/java/org/apache/maven/mercury/artifact/version/ComparableVersionTest.java
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: 
maven/mercury/trunk/mercury-artifact/src/test/java/org/apache/maven/mercury/artifact/version/ComparableVersionTest.java
------------------------------------------------------------------------------
    svn:keywords = Author Date Id Revision

Added: 
maven/mercury/trunk/mercury-artifact/src/test/java/org/apache/maven/mercury/artifact/version/DefaultArtifactVersionTest.java
URL: 
http://svn.apache.org/viewvc/maven/mercury/trunk/mercury-artifact/src/test/java/org/apache/maven/mercury/artifact/version/DefaultArtifactVersionTest.java?rev=726529&view=auto
==============================================================================
--- 
maven/mercury/trunk/mercury-artifact/src/test/java/org/apache/maven/mercury/artifact/version/DefaultArtifactVersionTest.java
 (added)
+++ 
maven/mercury/trunk/mercury-artifact/src/test/java/org/apache/maven/mercury/artifact/version/DefaultArtifactVersionTest.java
 Sun Dec 14 12:45:28 2008
@@ -0,0 +1,195 @@
+package org.apache.maven.mercury.artifact.version;
+
+/*
+ * 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;
+
+/**
+ * Test DefaultArtifactVersion.
+ *
+ * @author <a href="mailto:br...@apache.org";>Brett Porter</a>
+ * @version $Id$
+ */
+public class DefaultArtifactVersionTest
+    extends TestCase
+{
+    private ArtifactVersion newArtifactVersion( String version )
+    {
+        return new DefaultArtifactVersion( version );
+    }
+
+    private void checkVersionParsing( String version, int major, int minor, 
int incremental, int buildnumber,
+                                      String qualifier )
+    {
+        ArtifactVersion artifactVersion = newArtifactVersion( version );
+        String parsed = "'" + version + "' parsed as ('" + 
artifactVersion.getMajorVersion() + "', '"
+            + artifactVersion.getMinorVersion() + "', '" + 
artifactVersion.getIncrementalVersion() + "', '"
+            + artifactVersion.getBuildNumber() + "', '" + 
artifactVersion.getQualifier() + "'), ";
+        assertEquals( parsed + "check major version", major, 
artifactVersion.getMajorVersion() );
+        assertEquals( parsed + "check minor version", minor, 
artifactVersion.getMinorVersion() );
+        assertEquals( parsed + "check incremental version", incremental, 
artifactVersion.getIncrementalVersion() );
+        assertEquals( parsed + "check build number", buildnumber, 
artifactVersion.getBuildNumber() );
+        assertEquals( parsed + "check qualifier", qualifier, 
artifactVersion.getQualifier() );
+        assertEquals( "check " + version + " string value", version, 
artifactVersion.toString() );
+    }
+
+    public void testVersionParsing()
+    {
+        checkVersionParsing( "1" , 1, 0, 0, 0, null );
+        checkVersionParsing( "1.2" , 1, 2, 0, 0, null );
+        checkVersionParsing( "1.2.3" , 1, 2, 3, 0, null );
+        checkVersionParsing( "1.2.3-1" , 1, 2, 3, 1, null );
+        checkVersionParsing( "1.2.3-alpha-1" , 1, 2, 3, 0, "alpha-1" );
+        checkVersionParsing( "1.2-alpha-1" , 1, 2, 0, 0, "alpha-1" );
+        checkVersionParsing( "1.2-alpha-1-20050205.060708-1" , 1, 2, 0, 0, 
"alpha-1-20050205.060708-1" );
+        checkVersionParsing( "RELEASE" , 0, 0, 0, 0, "RELEASE" );
+        checkVersionParsing( "2.0-1" , 2, 0, 0, 1, null );
+
+        // 0 at the beginning of a number has a special handling
+        checkVersionParsing( "02" , 0, 0, 0, 0, "02" );
+        checkVersionParsing( "0.09" , 0, 0, 0, 0, "0.09" );
+        checkVersionParsing( "0.2.09" , 0, 0, 0, 0, "0.2.09" );
+        checkVersionParsing( "2.0-01" , 2, 0, 0, 0, "01" );
+
+        // version schemes not really supported: fully transformed as qualifier
+        checkVersionParsing( "1.0.1b" , 0, 0, 0, 0, "1.0.1b" );
+        checkVersionParsing( "1.0M2" , 0, 0, 0, 0, "1.0M2" );
+        checkVersionParsing( "1.0RC2" , 0, 0, 0, 0, "1.0RC2" );
+        checkVersionParsing( "1.7.3.0" , 0, 0, 0, 0, "1.7.3.0" );
+        checkVersionParsing( "1.7.3.0-1" , 0, 0, 0, 0, "1.7.3.0-1" );
+        checkVersionParsing( "PATCH-1193602" , 0, 0, 0, 0, "PATCH-1193602" );
+        checkVersionParsing( "5.0.0alpha-2006020117" , 0, 0, 0, 0, 
"5.0.0alpha-2006020117" );
+        checkVersionParsing( "1.0.0.-SNAPSHOT", 0, 0, 0, 0, "1.0.0.-SNAPSHOT" 
);
+        checkVersionParsing( "1..0-SNAPSHOT", 0, 0, 0, 0, "1..0-SNAPSHOT" );
+        checkVersionParsing( "1.0.-SNAPSHOT", 0, 0, 0, 0, "1.0.-SNAPSHOT" );
+        checkVersionParsing( ".1.0-SNAPSHOT", 0, 0, 0, 0, ".1.0-SNAPSHOT" );
+
+        checkVersionParsing( "1.2.3.200705301630" , 0, 0, 0, 0, 
"1.2.3.200705301630" );
+        checkVersionParsing( "1.2.3-200705301630" , 1, 2, 3, 0, "200705301630" 
);
+    }
+
+    public void testVersionComparing()
+    {
+        assertVersionEqual( "1", "1" );
+        assertVersionOlder( "1", "2" );
+        assertVersionOlder( "1.5", "2" );
+        assertVersionOlder( "1", "2.5" );
+        assertVersionEqual( "1", "1.0" );
+        assertVersionEqual( "1", "1.0.0" );
+        assertVersionOlder( "1.0", "1.1" );
+        assertVersionOlder( "1.1", "1.2" );
+        assertVersionOlder( "1.0.0", "1.1" );
+        assertVersionOlder( "1.1", "1.2.0" );
+
+        assertVersionOlder( "1.0-alpha-1", "1.0" );
+        assertVersionOlder( "1.0-alpha-1", "1.0-alpha-2" );
+        assertVersionOlder( "1.0-alpha-2", "1.0-alpha-15" );
+        assertVersionOlder( "1.0-alpha-1", "1.0-beta-1" );
+
+        assertVersionOlder( "1.0-SNAPSHOT", "1.0-beta-1" );
+        assertVersionOlder( "1.0-SNAPSHOT", "1.0" );
+        assertVersionOlder( "1.0-alpha-1-SNAPSHOT", "1.0-alpha-1" );
+
+        assertVersionOlder( "1.0", "1.0-1" );
+        assertVersionOlder( "1.0-1", "1.0-2" );
+        assertVersionEqual( "2.0-0", "2.0" );
+        assertVersionOlder( "2.0", "2.0-1" );
+        assertVersionOlder( "2.0.0", "2.0-1" );
+        assertVersionOlder( "2.0-1", "2.0.1" );
+
+        assertVersionOlder( "2.0.1-klm", "2.0.1-lmn" );
+        //assertVersionOlder( "2.0.1-xyz", "2.0.1" );
+
+        assertVersionOlder( "2.0.1", "2.0.1-123" );
+        assertVersionOlder( "2.0.1-xyz", "2.0.1-123" );
+
+        assertVersionOlder( "1.2.3-10000000000", "1.2.3-10000000001" );
+        assertVersionOlder( "1.2.3-1", "1.2.3-10000000001" );
+        assertVersionOlder( "2.3.0-v200706262000", "2.3.0-v200706262130" ); // 
org.eclipse:emf:2.3.0-v200706262000
+        // 
org.eclipse.wst.common_core.feature_2.0.0.v200706041905-7C78EK9E_EkMNfNOd2d8qq
+        assertVersionOlder( "2.0.0.v200706041905-7C78EK9E_EkMNfNOd2d8qq", 
"2.0.0.v200706041906-7C78EK9E_EkMNfNOd2d8qq" );
+    }
+
+    public void testVersionSnapshotComparing()
+    {
+        assertVersionEqual( "1-SNAPSHOT", "1-SNAPSHOT" );
+        assertVersionOlder( "1-SNAPSHOT", "2-SNAPSHOT" );
+        assertVersionOlder( "1.5-SNAPSHOT", "2-SNAPSHOT" );
+        assertVersionOlder( "1-SNAPSHOT", "2.5-SNAPSHOT" );
+        assertVersionEqual( "1-SNAPSHOT", "1.0-SNAPSHOT" );
+        assertVersionEqual( "1-SNAPSHOT", "1.0.0-SNAPSHOT" );
+        assertVersionOlder( "1.0-SNAPSHOT", "1.1-SNAPSHOT" );
+        assertVersionOlder( "1.1-SNAPSHOT", "1.2-SNAPSHOT" );
+        assertVersionOlder( "1.0.0-SNAPSHOT", "1.1-SNAPSHOT" );
+        assertVersionOlder( "1.1-SNAPSHOT", "1.2.0-SNAPSHOT" );
+
+        //assertVersionOlder( "1.0-alpha-1-SNAPSHOT", "1.0-SNAPSHOT" );
+        assertVersionOlder( "1.0-alpha-1-SNAPSHOT", "1.0-alpha-2-SNAPSHOT" );
+        assertVersionOlder( "1.0-alpha-1-SNAPSHOT", "1.0-beta-1-SNAPSHOT" );
+
+        assertVersionOlder( "1.0-SNAPSHOT-SNAPSHOT", "1.0-beta-1-SNAPSHOT" );
+        assertVersionOlder( "1.0-SNAPSHOT-SNAPSHOT", "1.0-SNAPSHOT" );
+        assertVersionOlder( "1.0-alpha-1-SNAPSHOT-SNAPSHOT", 
"1.0-alpha-1-SNAPSHOT" );
+
+        assertVersionOlder( "1.0-SNAPSHOT", "1.0-1-SNAPSHOT" );
+        assertVersionOlder( "1.0-1-SNAPSHOT", "1.0-2-SNAPSHOT" );
+        //assertVersionEqual( "2.0-0-SNAPSHOT", "2.0-SNAPSHOT" );
+        assertVersionOlder( "2.0-SNAPSHOT", "2.0-1-SNAPSHOT" );
+        assertVersionOlder( "2.0.0-SNAPSHOT", "2.0-1-SNAPSHOT" );
+        assertVersionOlder( "2.0-1-SNAPSHOT", "2.0.1-SNAPSHOT" );
+
+        assertVersionOlder( "2.0.1-klm-SNAPSHOT", "2.0.1-lmn-SNAPSHOT" );
+        // assertVersionOlder( "2.0.1-xyz-SNAPSHOT", "2.0.1-SNAPSHOT" );
+        assertVersionOlder( "2.0.1-SNAPSHOT", "2.0.1-123-SNAPSHOT" );
+        assertVersionOlder( "2.0.1-xyz-SNAPSHOT", "2.0.1-123-SNAPSHOT" );
+    }
+
+    public void testSnapshotVsReleases()
+    {
+        //assertVersionOlder( "1.0-RC1", "1.0-SNAPSHOT" ); not feasible if 
"1.0-SNAPSHOT" < "1.0-beta-1" too
+        assertVersionOlder( "1.0-SNAPSHOT", "1.0-RC1" );
+        assertVersionOlder( "1.0-SNAPSHOT", "1.0-rc1" );
+        assertVersionOlder( "1.0-SNAPSHOT", "1.0-rc-1" );
+    }
+
+    public void testHashCode()
+    {
+        ArtifactVersion v1 = newArtifactVersion( "1" );
+        ArtifactVersion v2 = newArtifactVersion( "1.0" );
+        assertEquals( true, v1.equals( v2 ) );
+        assertEquals( v1.hashCode(), v2.hashCode() );
+    }
+
+    private void assertVersionOlder( String left, String right )
+    {
+        assertTrue( left + " should be older than " + right,
+                    newArtifactVersion( left ).compareTo( newArtifactVersion( 
right ) ) < 0 );
+        assertTrue( right + " should be newer than " + left,
+                    newArtifactVersion( right ).compareTo( newArtifactVersion( 
left ) ) > 0 );
+    }
+
+    private void assertVersionEqual( String left, String right )
+    {
+        assertTrue( left + " should be equal to " + right,
+                    newArtifactVersion( left ).compareTo( newArtifactVersion( 
right ) ) == 0 );
+        assertTrue( right + " should be equal to " + left,
+                    newArtifactVersion( right ).compareTo( newArtifactVersion( 
left ) ) == 0 );
+    }
+}

Propchange: 
maven/mercury/trunk/mercury-artifact/src/test/java/org/apache/maven/mercury/artifact/version/DefaultArtifactVersionTest.java
------------------------------------------------------------------------------
    svn:eol-style = native

Propchange: 
maven/mercury/trunk/mercury-artifact/src/test/java/org/apache/maven/mercury/artifact/version/DefaultArtifactVersionTest.java
------------------------------------------------------------------------------
    svn:keywords = Author Date Id Revision


Reply via email to