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