diff options
author | Brett Porter <brett@apache.org> | 2008-02-19 08:35:55 +0000 |
---|---|---|
committer | Brett Porter <brett@apache.org> | 2008-02-19 08:35:55 +0000 |
commit | a13e30feb5154c0be51fa5857d1d78e2f645dd30 (patch) | |
tree | 080c5f25ce2e5901c3846e3fd3bcaa0d6bed977a /archiva-base/archiva-repository-layer/src | |
parent | d23dd72c419e1131741baef0bff6e1f5e1b20cac (diff) | |
download | archiva-a13e30feb5154c0be51fa5857d1d78e2f645dd30.tar.gz archiva-a13e30feb5154c0be51fa5857d1d78e2f645dd30.zip |
[MRM-703] Artifacts with extensions longer than fours characters breaks repository scanning
Submitted by: Jim Jackson
Merged from: r629020 on archiva-1.0.x branch
git-svn-id: https://svn.apache.org/repos/asf/maven/archiva/trunk@629023 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'archiva-base/archiva-repository-layer/src')
2 files changed, 29 insertions, 21 deletions
diff --git a/archiva-base/archiva-repository-layer/src/main/java/org/apache/maven/archiva/repository/content/FilenameParser.java b/archiva-base/archiva-repository-layer/src/main/java/org/apache/maven/archiva/repository/content/FilenameParser.java index 3778e5ed2..173716523 100644 --- a/archiva-base/archiva-repository-layer/src/main/java/org/apache/maven/archiva/repository/content/FilenameParser.java +++ b/archiva-base/archiva-repository-layer/src/main/java/org/apache/maven/archiva/repository/content/FilenameParser.java @@ -40,7 +40,7 @@ public class FilenameParser private static final Pattern mavenPluginPattern = Pattern.compile( "(maven-.*-plugin)|(.*-maven-plugin)" ); - private static final Pattern extensionPattern = Pattern.compile( "(.tar.gz$)|(.tar.bz2$)|(.[a-z0-9]{1,4}$)", + private static final Pattern extensionPattern = Pattern.compile( "(.tar.gz$)|(.tar.bz2$)|(.[a-z0-9]*$)", Pattern.CASE_INSENSITIVE ); private static final Pattern section = Pattern.compile( "([^-]*)" ); diff --git a/archiva-base/archiva-repository-layer/src/test/java/org/apache/maven/archiva/repository/content/FilenameParserTest.java b/archiva-base/archiva-repository-layer/src/test/java/org/apache/maven/archiva/repository/content/FilenameParserTest.java index 9c98fc237..23924aa55 100644 --- a/archiva-base/archiva-repository-layer/src/test/java/org/apache/maven/archiva/repository/content/FilenameParserTest.java +++ b/archiva-base/archiva-repository-layer/src/test/java/org/apache/maven/archiva/repository/content/FilenameParserTest.java @@ -22,7 +22,7 @@ package org.apache.maven.archiva.repository.content; import junit.framework.TestCase; /** - * FilenameParserTest + * FilenameParserTest * * @author <a href="mailto:joakime@apache.org">Joakim Erdfelt</a> * @version $Id$ @@ -45,7 +45,7 @@ public class FilenameParserTest assertEquals( "archiva-1.0-beta-2-bin", parser.getName() ); assertEquals( "tar.gz", parser.getExtension() ); } - + public void testNameExtensionTarBz2() { FilenameParser parser = new FilenameParser( "archiva-1.0-SNAPSHOT-src.tar.bz2" ); @@ -68,7 +68,7 @@ public class FilenameParserTest assertEquals( "maven-test-plugin-1.8.3", parser.getName() ); assertEquals( "jar", parser.getExtension() ); - + assertEquals( "maven", parser.next() ); assertEquals( "test", parser.next() ); assertEquals( "plugin", parser.next() ); @@ -87,7 +87,7 @@ public class FilenameParserTest assertEquals( "1.8.3", parser.expect( "1.8.3" ) ); assertNull( parser.expect( "jar" ) ); } - + public void testExpectWithRemaining() { FilenameParser parser = new FilenameParser( "ganymede-ssh2-build250-sources.jar" ); @@ -99,10 +99,10 @@ public class FilenameParserTest assertEquals( "build250", parser.expect( "build250" ) ); assertEquals( '-', parser.seperator() ); assertEquals( "sources", parser.remaining() ); - + assertNull( parser.expect( "jar" ) ); } - + public void testExpectWithRemainingDualExtensions() { FilenameParser parser = new FilenameParser( "example-presentation-3.2.xml.zip" ); @@ -114,31 +114,39 @@ public class FilenameParserTest assertEquals( "3.2", parser.expect( "3.2" ) ); assertEquals( '.', parser.seperator() ); assertEquals( "xml", parser.remaining() ); - - } - + + } + public void testNextNonVersion() { FilenameParser parser = new FilenameParser( "maven-test-plugin-1.8.3.jar" ); - - assertEquals("maven-test-plugin", parser.nextNonVersion() ); - assertEquals("1.8.3", parser.remaining() ); + + assertEquals( "maven-test-plugin", parser.nextNonVersion() ); + assertEquals( "1.8.3", parser.remaining() ); } - + public void testNextArbitraryNonVersion() { FilenameParser parser = new FilenameParser( "maven-jdk-1.4-plugin-1.0-20070828.123456-42.jar" ); - - assertEquals("maven-jdk-1.4-plugin", parser.nextNonVersion() ); - assertEquals("1.0-20070828.123456-42", parser.remaining() ); + + assertEquals( "maven-jdk-1.4-plugin", parser.nextNonVersion() ); + assertEquals( "1.0-20070828.123456-42", parser.remaining() ); } public void testNextJython() { FilenameParser parser = new FilenameParser( "jython-20020827-no-oro.jar" ); - - assertEquals("jython", parser.nextNonVersion() ); - assertEquals("20020827", parser.nextVersion() ); - assertEquals("no-oro", parser.remaining() ); + + assertEquals( "jython", parser.nextNonVersion() ); + assertEquals( "20020827", parser.nextVersion() ); + assertEquals( "no-oro", parser.remaining() ); + } + + public void testLongExtension() + { + FilenameParser parser = new FilenameParser( "libfobs4jmf-0.4.1.4-20080217.211715-4.jnilib" ); + + assertEquals( "libfobs4jmf-0.4.1.4-20080217.211715-4", parser.getName() ); + assertEquals( "jnilib", parser.getExtension() ); } } |