123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819 |
- package org.apache.archiva.maven.repository.metadata.storage;
-
- /*
- * 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 org.apache.archiva.configuration.provider.ArchivaConfiguration;
- import org.apache.archiva.configuration.model.Configuration;
- import org.apache.archiva.configuration.model.ManagedRepositoryConfiguration;
- import org.apache.archiva.configuration.model.ProxyConnectorConfiguration;
- import org.apache.archiva.configuration.model.RemoteRepositoryConfiguration;
- import org.apache.archiva.configuration.model.RepositoryScanningConfiguration;
- import org.apache.archiva.filter.AllFilter;
- import org.apache.archiva.filter.ExcludesFilter;
- import org.apache.archiva.filter.Filter;
- import org.apache.archiva.maven.metadata.model.MavenArtifactFacet;
- import org.apache.archiva.metadata.model.ArtifactMetadata;
- import org.apache.archiva.metadata.model.Dependency;
- import org.apache.archiva.metadata.model.License;
- import org.apache.archiva.metadata.model.MailingList;
- import org.apache.archiva.metadata.model.ProjectVersionMetadata;
- import org.apache.archiva.metadata.repository.storage.ReadMetadataRequest;
- import org.apache.archiva.metadata.repository.storage.RepositoryStorageMetadataInvalidException;
- import org.apache.archiva.metadata.repository.storage.RepositoryStorageMetadataNotFoundException;
- import org.apache.archiva.maven.common.proxy.WagonFactory;
- import org.apache.archiva.maven.common.proxy.WagonFactoryRequest;
- import org.apache.archiva.repository.RepositoryRegistry;
- import org.apache.archiva.repository.base.RepositoryHandlerDependencies;
- import org.apache.archiva.test.utils.ArchivaSpringJUnit4ClassRunner;
- import org.apache.commons.io.FileUtils;
- import org.apache.maven.wagon.Wagon;
- import org.junit.Before;
- import org.junit.Test;
- import org.junit.runner.RunWith;
- import org.springframework.test.context.ContextConfiguration;
-
- import javax.inject.Inject;
- import javax.inject.Named;
- import java.io.IOException;
- import java.net.URL;
- import java.nio.file.Files;
- import java.nio.file.Path;
- import java.nio.file.Paths;
- import java.nio.file.StandardCopyOption;
- import java.util.ArrayList;
- import java.util.Arrays;
- import java.util.Collection;
- import java.util.Collections;
- import java.util.Comparator;
- import java.util.List;
-
- import static org.mockito.Mockito.mock;
- import static org.mockito.Mockito.when;
-
- @RunWith ( ArchivaSpringJUnit4ClassRunner.class )
- @ContextConfiguration ( { "classpath*:/META-INF/spring-context.xml", "classpath:/spring-context.xml" } )
- public class Maven2RepositoryMetadataResolverTest
- extends TestCase
- {
- private static final Filter<String> ALL = new AllFilter<String>();
-
- @Inject
- @Named ( "repositoryStorage#maven2" )
- private Maven2RepositoryStorage storage;
-
- @Inject
- RepositoryRegistry repositoryRegistry;
-
- @SuppressWarnings( "unused" )
- @Inject
- RepositoryHandlerDependencies repositoryHandlerDependencies;
-
-
- private static final String TEST_REPO_ID = "test";
-
- private static final String TEST_REMOTE_REPO_ID = "central";
-
- private static final String ASF_SCM_CONN_BASE = "scm:svn:http://svn.apache.org/repos/asf/";
-
- private static final String ASF_SCM_DEV_CONN_BASE = "scm:svn:https://svn.apache.org/repos/asf/";
-
- private static final String ASF_SCM_VIEWVC_BASE = "http://svn.apache.org/viewvc/";
-
- private static final String TEST_SCM_CONN_BASE = "scm:svn:http://svn.example.com/repos/";
-
- private static final String TEST_SCM_DEV_CONN_BASE = "scm:svn:https://svn.example.com/repos/";
-
- private static final String TEST_SCM_URL_BASE = "http://svn.example.com/repos/";
-
- private static final String EMPTY_MD5 = "d41d8cd98f00b204e9800998ecf8427e";
-
- private static final String EMPTY_SHA1 = "da39a3ee5e6b4b0d3255bfef95601890afd80709";
-
- @Inject
- @Named ( "archivaConfiguration#default" )
- protected ArchivaConfiguration configuration;
-
- private WagonFactory wagonFactory;
-
- ManagedRepositoryConfiguration testRepo;
-
- Configuration c;
-
- @Before
- @Override
- public void setUp()
- throws Exception
- {
- super.setUp();
-
- c = new Configuration();
-
- c.setVersion("2.0");
- testRepo = new ManagedRepositoryConfiguration();
- testRepo.setId( TEST_REPO_ID );
- testRepo.setLocation( Paths.get( "target/test-repository" ).toAbsolutePath().toString() );
- testRepo.setReleases( true );
- testRepo.setSnapshots( true );
- c.addManagedRepository( testRepo );
-
- RemoteRepositoryConfiguration testRemoteRepo = new RemoteRepositoryConfiguration();
- testRemoteRepo.setId( TEST_REMOTE_REPO_ID );
- testRemoteRepo.setLayout( "default" );
- testRemoteRepo.setName( "Central Repository" );
- testRemoteRepo.setUrl( "http://central.repo.com/maven2" );
- testRemoteRepo.setTimeout( 10 );
- c.addRemoteRepository( testRemoteRepo );
-
- ProxyConnectorConfiguration proxyConnector = new ProxyConnectorConfiguration();
- proxyConnector.setSourceRepoId( TEST_REPO_ID );
- proxyConnector.setTargetRepoId( TEST_REMOTE_REPO_ID );
- proxyConnector.setDisabled( false );
- c.addProxyConnector( proxyConnector );
-
- RepositoryScanningConfiguration scCfg = new RepositoryScanningConfiguration();
- c.setRepositoryScanning(scCfg);
-
- configuration.save( c );
- assertFalse(configuration.isDefaulted());
- repositoryRegistry.reload();
-
- assertTrue( c.getManagedRepositories().get( 0 ).isSnapshots() );
- assertTrue( c.getManagedRepositories().get( 0 ).isReleases() );
-
- wagonFactory = mock( WagonFactory.class );
-
- storage.setWagonFactory( wagonFactory );
-
- Wagon wagon = new MockWagon();
- when( wagonFactory.getWagon( new WagonFactoryRequest().protocol( "wagon#http" ) ) ).thenReturn( wagon );
- }
-
- @Test
- public void testModelWithJdkProfileActivation()
- throws Exception
- {
- ReadMetadataRequest readMetadataRequest =
- new ReadMetadataRequest().repositoryId( TEST_REPO_ID ).namespace( "org.apache.maven" ).projectId(
- "maven-archiver" ).projectVersion( "2.4.1" );
- ProjectVersionMetadata metadata = storage.readProjectVersionMetadata( readMetadataRequest );
- MavenProjectFacet facet = (MavenProjectFacet) metadata.getFacet( MavenProjectFacet.FACET_ID );
- }
-
- @Test
- public void testGetProjectVersionMetadata()
- throws Exception
- {
- ProjectVersionMetadata metadata = storage.readProjectVersionMetadata(
- new ReadMetadataRequest( TEST_REPO_ID, "org.apache.archiva", "archiva-common", "1.2.1" ) );
- MavenProjectFacet facet = (MavenProjectFacet) metadata.getFacet( MavenProjectFacet.FACET_ID );
- assertEquals( "jar", facet.getPackaging() );
- assertEquals( "http://archiva.apache.org/ref/1.2.1/archiva-base/archiva-common", metadata.getUrl() );
- assertEquals( "org.apache.archiva", facet.getParent().getGroupId() );
- assertEquals( "archiva-base", facet.getParent().getArtifactId() );
- assertEquals( "1.2.1", facet.getParent().getVersion() );
- assertEquals( "archiva-common", facet.getArtifactId() );
- assertEquals( "org.apache.archiva", facet.getGroupId() );
- assertEquals( "continuum", metadata.getCiManagement().getSystem() );
- assertEquals( "http://vmbuild.apache.org/continuum", metadata.getCiManagement().getUrl() );
- assertNotNull( metadata.getDescription() );
- // TODO: this would be better
- // assertEquals(
- // "Archiva is an application for managing one or more remote repositories, including administration, artifact handling, browsing and searching.",
- // metadata.getDescription() );
- assertEquals( "1.2.1", metadata.getId() );
- assertEquals( "jira", metadata.getIssueManagement().getSystem() );
- assertEquals( "http://jira.codehaus.org/browse/MRM", metadata.getIssueManagement().getUrl() );
- checkApacheLicense( metadata );
- assertEquals( "Archiva Base :: Common", metadata.getName() );
- String path = "archiva/tags/archiva-1.2.1/archiva-modules/archiva-base/archiva-common";
- assertEquals( ASF_SCM_CONN_BASE + path, metadata.getScm().getConnection() );
- assertEquals( ASF_SCM_DEV_CONN_BASE + path, metadata.getScm().getDeveloperConnection() );
- assertEquals( ASF_SCM_VIEWVC_BASE + path, metadata.getScm().getUrl() );
- checkOrganizationApache( metadata );
-
- assertEquals( 4, metadata.getMailingLists().size() );
- assertMailingList( "users", metadata.getMailingLists().get( 0 ), "Archiva User List", true,
- "http://www.nabble.com/archiva-users-f16426.html" );
- assertMailingList( "dev", metadata.getMailingLists().get( 1 ), "Archiva Developer List", true,
- "http://www.nabble.com/archiva-dev-f16427.html" );
- assertMailingList( "commits", metadata.getMailingLists().get( 2 ), "Archiva Commits List", false, null );
- assertMailingList( "issues", metadata.getMailingLists().get( 3 ), "Archiva Issues List", false,
- "http://www.nabble.com/Archiva---Issues-f29617.html" );
-
- List<Dependency> dependencies = metadata.getDependencies();
- assertEquals( 9, dependencies.size() );
- assertDependency( dependencies.get( 0 ), "commons-lang", "commons-lang", "2.2" );
- assertDependency( dependencies.get( 1 ), "commons-io", "commons-io", "1.4" );
- assertDependency( dependencies.get( 2 ), "org.slf4j", "slf4j-api", "1.5.0" );
- assertDependency( dependencies.get( 3 ), "org.codehaus.plexus", "plexus-component-api", "1.0-alpha-22" );
- assertDependency( dependencies.get( 4 ), "org.codehaus.plexus", "plexus-spring", "1.2", "test" );
- assertDependency( dependencies.get( 5 ), "xalan", "xalan", "2.7.0" );
- assertDependency( dependencies.get( 6 ), "junit", "junit", "3.8.1", "test" );
- assertDependency( dependencies.get( 7 ), "easymock", "easymock", "1.2_Java1.3", "test" );
- assertDependency( dependencies.get( 8 ), "easymock", "easymockclassextension", "1.2", "test" );
-
- assertEquals( 8, metadata.getProperties().size() );
- assertEquals( "http://www.apache.org/images/asf_logo_wide.gif", metadata.getProperties().get("organization.logo") );
- }
-
- @Test
- public void testGetArtifactMetadata()
- throws Exception
- {
- Collection<ArtifactMetadata> springArtifacts = storage.readArtifactsMetadata(
- new ReadMetadataRequest( TEST_REPO_ID, "org.codehaus.plexus", "plexus-spring", "1.2", ALL ) );
- List<ArtifactMetadata> artifacts = new ArrayList<>( springArtifacts );
- Collections.sort( artifacts, new Comparator<ArtifactMetadata>()
- {
- @Override
- public int compare( ArtifactMetadata o1, ArtifactMetadata o2 )
- {
- return o1.getId().compareTo( o2.getId() );
- }
- } );
-
- assertEquals( 3, artifacts.size() );
-
- ArtifactMetadata artifactMetadata = artifacts.get( 0 );
- assertEquals( "plexus-spring-1.2-sources.jar", artifactMetadata.getId() );
- MavenArtifactFacet facet = (MavenArtifactFacet) artifactMetadata.getFacet( MavenArtifactFacet.FACET_ID );
- assertEquals( 0, facet.getBuildNumber() );
- assertNull( facet.getTimestamp() );
- assertEquals( "sources", facet.getClassifier() );
- assertEquals( "java-source", facet.getType() );
-
- artifactMetadata = artifacts.get( 1 );
- assertEquals( "plexus-spring-1.2.jar", artifactMetadata.getId() );
- facet = (MavenArtifactFacet) artifactMetadata.getFacet( MavenArtifactFacet.FACET_ID );
- assertEquals( 0, facet.getBuildNumber() );
- assertNull( facet.getTimestamp() );
- assertNull( facet.getClassifier() );
- assertEquals( "jar", facet.getType() );
-
- artifactMetadata = artifacts.get( 2 );
- assertEquals( "plexus-spring-1.2.pom", artifactMetadata.getId() );
- facet = (MavenArtifactFacet) artifactMetadata.getFacet( MavenArtifactFacet.FACET_ID );
- assertEquals( 0, facet.getBuildNumber() );
- assertNull( facet.getTimestamp() );
- assertNull( facet.getClassifier() );
- assertEquals( "pom", facet.getType() );
- }
-
- @Test
- public void testGetArtifactMetadataSnapshots()
- throws Exception
- {
- Collection<ArtifactMetadata> testArtifacts = storage.readArtifactsMetadata(
- new ReadMetadataRequest( TEST_REPO_ID, "com.example.test", "test-artifact", "1.0-SNAPSHOT", ALL ) );
- List<ArtifactMetadata> artifacts = new ArrayList<>( testArtifacts );
- Collections.sort( artifacts, new Comparator<ArtifactMetadata>()
- {
- @Override
- public int compare( ArtifactMetadata o1, ArtifactMetadata o2 )
- {
- return o1.getId().compareTo( o2.getId() );
- }
- } );
-
- assertEquals( 6, artifacts.size() );
-
- ArtifactMetadata artifactMetadata = artifacts.get( 0 );
- assertEquals( "test-artifact-1.0-20100308.230825-1.jar", artifactMetadata.getId() );
- MavenArtifactFacet facet = (MavenArtifactFacet) artifactMetadata.getFacet( MavenArtifactFacet.FACET_ID );
- assertEquals( 1, facet.getBuildNumber() );
- assertEquals( "20100308.230825", facet.getTimestamp() );
- assertNull( facet.getClassifier() );
- assertEquals( "jar", facet.getType() );
-
- artifactMetadata = artifacts.get( 1 );
- assertEquals( "test-artifact-1.0-20100308.230825-1.pom", artifactMetadata.getId() );
- facet = (MavenArtifactFacet) artifactMetadata.getFacet( MavenArtifactFacet.FACET_ID );
- assertEquals( 1, facet.getBuildNumber() );
- assertEquals( "20100308.230825", facet.getTimestamp() );
- assertNull( facet.getClassifier() );
- assertEquals( "pom", facet.getType() );
-
- artifactMetadata = artifacts.get( 2 );
- assertEquals( "test-artifact-1.0-20100310.014828-2-javadoc.jar", artifactMetadata.getId() );
- facet = (MavenArtifactFacet) artifactMetadata.getFacet( MavenArtifactFacet.FACET_ID );
- assertEquals( 2, facet.getBuildNumber() );
- assertEquals( "20100310.014828", facet.getTimestamp() );
- assertEquals( "javadoc", facet.getClassifier() );
- assertEquals( "javadoc", facet.getType() );
-
- artifactMetadata = artifacts.get( 3 );
- assertEquals( "test-artifact-1.0-20100310.014828-2-sources.jar", artifactMetadata.getId() );
- facet = (MavenArtifactFacet) artifactMetadata.getFacet( MavenArtifactFacet.FACET_ID );
- assertEquals( 2, facet.getBuildNumber() );
- assertEquals( "20100310.014828", facet.getTimestamp() );
- assertEquals( "sources", facet.getClassifier() );
- assertEquals( "java-source", facet.getType() );
-
- artifactMetadata = artifacts.get( 4 );
- assertEquals( "test-artifact-1.0-20100310.014828-2.jar", artifactMetadata.getId() );
- facet = (MavenArtifactFacet) artifactMetadata.getFacet( MavenArtifactFacet.FACET_ID );
- assertEquals( 2, facet.getBuildNumber() );
- assertEquals( "20100310.014828", facet.getTimestamp() );
- assertNull( facet.getClassifier() );
- assertEquals( "jar", facet.getType() );
-
- artifactMetadata = artifacts.get( 5 );
- assertEquals( "test-artifact-1.0-20100310.014828-2.pom", artifactMetadata.getId() );
- facet = (MavenArtifactFacet) artifactMetadata.getFacet( MavenArtifactFacet.FACET_ID );
- assertEquals( 2, facet.getBuildNumber() );
- assertEquals( "20100310.014828", facet.getTimestamp() );
- assertNull( facet.getClassifier() );
- assertEquals( "pom", facet.getType() );
- }
-
- @Test
- public void testGetArtifactMetadataSnapshotsMRM1859()
- throws Exception
- {
- Path repoDir = Paths.get("target/test-repository/com/example/test/test-artifact/1.0-SNAPSHOT");
- URL url = Thread.currentThread().getContextClassLoader().getResource("resolver-status.properties");
- Path resFile = Paths.get(url.toURI());
- Path destFile = repoDir.resolve(resFile.getFileName());
- Files.copy(resFile, destFile, StandardCopyOption.REPLACE_EXISTING);
- URL url2 = Thread.currentThread().getContextClassLoader().getResource("test01.properties");
- Path resFile2 = Paths.get(url2.toURI());
- Path destFile2 = repoDir.resolve(resFile2.getFileName());
- Files.copy(resFile2, destFile2, StandardCopyOption.REPLACE_EXISTING);
-
- try {
-
-
- Collection<ArtifactMetadata> testArtifacts = storage.readArtifactsMetadata(
- new ReadMetadataRequest(TEST_REPO_ID, "com.example.test", "test-artifact", "1.0-SNAPSHOT", ALL));
- List<ArtifactMetadata> artifacts = new ArrayList<>(testArtifacts);
- Collections.sort(artifacts, new Comparator<ArtifactMetadata>() {
- @Override
- public int compare(ArtifactMetadata o1, ArtifactMetadata o2) {
- return o1.getId().compareTo(o2.getId());
- }
- });
-
- assertEquals(6, artifacts.size());
-
- ArtifactMetadata artifactMetadata = artifacts.get(0);
- assertEquals("test-artifact-1.0-20100308.230825-1.jar", artifactMetadata.getId());
- MavenArtifactFacet facet = (MavenArtifactFacet) artifactMetadata.getFacet(MavenArtifactFacet.FACET_ID);
- assertEquals(1, facet.getBuildNumber());
- assertEquals("20100308.230825", facet.getTimestamp());
- assertNull(facet.getClassifier());
- assertEquals("jar", facet.getType());
-
- artifactMetadata = artifacts.get(1);
- assertEquals("test-artifact-1.0-20100308.230825-1.pom", artifactMetadata.getId());
- facet = (MavenArtifactFacet) artifactMetadata.getFacet(MavenArtifactFacet.FACET_ID);
- assertEquals(1, facet.getBuildNumber());
- assertEquals("20100308.230825", facet.getTimestamp());
- assertNull(facet.getClassifier());
- assertEquals("pom", facet.getType());
-
- artifactMetadata = artifacts.get(2);
- assertEquals("test-artifact-1.0-20100310.014828-2-javadoc.jar", artifactMetadata.getId());
- facet = (MavenArtifactFacet) artifactMetadata.getFacet(MavenArtifactFacet.FACET_ID);
- assertEquals(2, facet.getBuildNumber());
- assertEquals("20100310.014828", facet.getTimestamp());
- assertEquals("javadoc", facet.getClassifier());
- assertEquals("javadoc", facet.getType());
-
- artifactMetadata = artifacts.get(3);
- assertEquals("test-artifact-1.0-20100310.014828-2-sources.jar", artifactMetadata.getId());
- facet = (MavenArtifactFacet) artifactMetadata.getFacet(MavenArtifactFacet.FACET_ID);
- assertEquals(2, facet.getBuildNumber());
- assertEquals("20100310.014828", facet.getTimestamp());
- assertEquals("sources", facet.getClassifier());
- assertEquals("java-source", facet.getType());
-
- artifactMetadata = artifacts.get(4);
- assertEquals("test-artifact-1.0-20100310.014828-2.jar", artifactMetadata.getId());
- facet = (MavenArtifactFacet) artifactMetadata.getFacet(MavenArtifactFacet.FACET_ID);
- assertEquals(2, facet.getBuildNumber());
- assertEquals("20100310.014828", facet.getTimestamp());
- assertNull(facet.getClassifier());
- assertEquals("jar", facet.getType());
-
- artifactMetadata = artifacts.get(5);
- assertEquals("test-artifact-1.0-20100310.014828-2.pom", artifactMetadata.getId());
- facet = (MavenArtifactFacet) artifactMetadata.getFacet(MavenArtifactFacet.FACET_ID);
- assertEquals(2, facet.getBuildNumber());
- assertEquals("20100310.014828", facet.getTimestamp());
- assertNull(facet.getClassifier());
- assertEquals("pom", facet.getType());
-
- } finally {
- Files.delete(destFile);
- Files.delete(destFile2);
- }
-
- }
-
- private void assertDependency( Dependency dependency, String groupId, String artifactId, String version )
- {
- assertDependency( dependency, groupId, artifactId, version, "compile" );
- }
-
- private void assertDependency( Dependency dependency, String groupId, String artifactId, String version,
- String scope )
- {
- assertEquals( artifactId, dependency.getArtifactId() );
- assertEquals( "jar", dependency.getType() );
- assertEquals( version, dependency.getVersion() );
- assertEquals( groupId, dependency.getNamespace() );
- assertEquals( scope, dependency.getScope() );
- assertNull( dependency.getClassifier() );
- assertNull( dependency.getSystemPath() );
- }
-
- @Test
- public void testGetProjectVersionMetadataForTimestampedSnapshot()
- throws Exception
- {
- ProjectVersionMetadata metadata = storage.readProjectVersionMetadata(
- new ReadMetadataRequest( TEST_REPO_ID, "org.apache", "apache", "5-SNAPSHOT" ) );
- MavenProjectFacet facet = MavenProjectFacet.class.cast( metadata.getFacet( MavenProjectFacet.FACET_ID ) );
- assertEquals( "pom", facet.getPackaging() );
- assertEquals( "http://www.apache.org/", metadata.getUrl() );
- assertNull( facet.getParent() );
- assertEquals( "org.apache", facet.getGroupId() );
- assertEquals( "apache", facet.getArtifactId() );
- assertNull( metadata.getCiManagement() );
- assertNotNull( metadata.getDescription() );
- // TODO: this would be better
- // assertEquals(
- // "The Apache Software Foundation provides support for the Apache community of open-source software projects. " +
- // "The Apache projects are characterized by a collaborative, consensus based development process, an open " +
- // "and pragmatic software license, and a desire to create high quality software that leads the way in its " +
- // "field. We consider ourselves not simply a group of projects sharing a server, but rather a community of " +
- // "developers and users.", metadata.getDescription() );
- assertEquals( "5-SNAPSHOT", metadata.getId() );
- assertNull( metadata.getIssueManagement() );
- checkApacheLicense( metadata );
- assertEquals( "The Apache Software Foundation", metadata.getName() );
- String path = "maven/pom/trunk/asf";
- assertEquals( ASF_SCM_CONN_BASE + path, metadata.getScm().getConnection() );
- assertEquals( ASF_SCM_DEV_CONN_BASE + path, metadata.getScm().getDeveloperConnection() );
- assertEquals( ASF_SCM_VIEWVC_BASE + path, metadata.getScm().getUrl() );
- checkOrganizationApache( metadata );
- assertEquals( 1, metadata.getMailingLists().size() );
- assertMailingList( metadata.getMailingLists().get( 0 ), "Apache Announce List",
- "http://mail-archives.apache.org/mod_mbox/www-announce/", "announce@apache.org",
- "announce-subscribe@apache.org", "announce-unsubscribe@apache.org",
- Collections.<String>emptyList(), true );
- assertEquals( Collections.<Dependency>emptyList(), metadata.getDependencies() );
- }
-
- @Test
- public void testGetProjectVersionMetadataForTimestampedSnapshotMissingMetadata()
- throws Exception
- {
- try
- {
- storage.readProjectVersionMetadata(
- new ReadMetadataRequest( TEST_REPO_ID, "com.example.test", "missing-metadata", "1.0-SNAPSHOT" ) );
- fail( "Should not be found" );
- }
- catch ( RepositoryStorageMetadataNotFoundException e )
- {
- assertEquals( "missing-pom", e.getId() );
- }
- }
-
- @Test
- public void testGetProjectVersionMetadataForTimestampedSnapshotMalformedMetadata()
- throws Exception
- {
- try
- {
- storage.readProjectVersionMetadata(
- new ReadMetadataRequest( TEST_REPO_ID, "com.example.test", "malformed-metadata", "1.0-SNAPSHOT" ) );
- fail( "Should not be found" );
- }
- catch ( RepositoryStorageMetadataNotFoundException e )
- {
- assertEquals( "missing-pom", e.getId() );
- }
- }
-
- @Test
- public void testGetProjectVersionMetadataForTimestampedSnapshotIncompleteMetadata()
- throws Exception
- {
- try
- {
- storage.readProjectVersionMetadata(
- new ReadMetadataRequest( TEST_REPO_ID, "com.example.test", "incomplete-metadata", "1.0-SNAPSHOT" ) );
- fail( "Should not be found" );
- }
- catch ( RepositoryStorageMetadataNotFoundException e )
- {
- assertEquals( "missing-pom", e.getId() );
- }
- }
-
- @Test
- public void testGetProjectVersionMetadataForInvalidPom()
- throws Exception
- {
- try
- {
- storage.readProjectVersionMetadata(
- new ReadMetadataRequest( TEST_REPO_ID, "com.example.test", "invalid-pom", "1.0" ) );
- fail( "Should have received an exception due to invalid POM" );
- }
- catch ( RepositoryStorageMetadataInvalidException e )
- {
- assertEquals( "invalid-pom", e.getId() );
- }
- }
-
- @Test
- public void testGetProjectVersionMetadataForMislocatedPom()
- throws Exception
- {
- try
- {
- storage.readProjectVersionMetadata(
- new ReadMetadataRequest( TEST_REPO_ID, "com.example.test", "mislocated-pom", "1.0" ) );
- fail( "Should have received an exception due to mislocated POM" );
- }
- catch ( RepositoryStorageMetadataInvalidException e )
- {
- assertEquals( "mislocated-pom", e.getId() );
- }
- }
-
- @Test
- public void testGetProjectVersionMetadataForMissingPom()
- throws Exception
- {
- try
- {
- storage.readProjectVersionMetadata(
- new ReadMetadataRequest( TEST_REPO_ID, "com.example.test", "missing-pom", "1.0" ) );
- fail( "Should not be found" );
- }
- catch ( RepositoryStorageMetadataNotFoundException e )
- {
- assertEquals( "missing-pom", e.getId() );
- }
- }
-
- @Test
- public void testGetRootNamespaces()
- throws Exception
- {
- assertEquals( Arrays.asList( "com", "org"), storage.listRootNamespaces( TEST_REPO_ID, ALL ) );
- }
-
- @Test
- public void testGetNamespaces()
- throws Exception
- {
- assertEquals( Arrays.asList( "example" ), storage.listNamespaces( TEST_REPO_ID, "com", ALL ) );
- assertEquals( Arrays.asList( "test" ), storage.listNamespaces( TEST_REPO_ID, "com.example", ALL ) );
- assertEquals( Collections.<String>emptyList(),
- storage.listNamespaces( TEST_REPO_ID, "com.example.test", ALL ) );
-
- assertEquals( Arrays.asList( "apache", "codehaus" ), storage.listNamespaces( TEST_REPO_ID, "org", ALL ) );
- assertEquals( Arrays.asList( "archiva", "maven" ), storage.listNamespaces( TEST_REPO_ID, "org.apache", ALL ) );
- assertEquals( Collections.<String>emptyList(),
- storage.listNamespaces( TEST_REPO_ID, "org.apache.archiva", ALL ) );
- assertEquals( Arrays.asList( "plugins", "shared" ),
- storage.listNamespaces( TEST_REPO_ID, "org.apache.maven", ALL ) );
- assertEquals( Collections.<String>emptyList(),
- storage.listNamespaces( TEST_REPO_ID, "org.apache.maven.plugins", ALL ) );
- assertEquals( Collections.<String>emptyList(),
- storage.listNamespaces( TEST_REPO_ID, "org.apache.maven.shared", ALL ) );
-
- assertEquals( Arrays.asList( "plexus" ), storage.listNamespaces( TEST_REPO_ID, "org.codehaus", ALL ) );
- assertEquals( Collections.<String>emptyList(),
- storage.listNamespaces( TEST_REPO_ID, "org.codehaus.plexus", ALL ) );
- }
-
- @Test
- public void testGetProjects()
- throws Exception
- {
- assertEquals( Collections.<String>emptyList(), storage.listProjects( TEST_REPO_ID, "com", ALL ) );
- assertEquals( Collections.<String>emptyList(), storage.listProjects( TEST_REPO_ID, "com.example", ALL ) );
- assertEquals( Arrays.asList( "incomplete-metadata", "invalid-pom", "malformed-metadata", "mislocated-pom",
- "missing-metadata", "missing-parent", "test-artifact" ),
- storage.listProjects( TEST_REPO_ID, "com.example.test", ALL ) );
-
- assertEquals( Collections.<String>emptyList(), storage.listProjects( TEST_REPO_ID, "org", ALL ) );
- assertEquals( Arrays.asList( "apache" ), storage.listProjects( TEST_REPO_ID, "org.apache", ALL ) );
- assertEquals( Arrays.asList( "archiva", "archiva-base", "archiva-common", "archiva-modules", "archiva-parent" ),
- storage.listProjects( TEST_REPO_ID, "org.apache.archiva", ALL ) );
- assertEquals( Arrays.asList( "maven-archiver", "maven-parent" ),
- storage.listProjects( TEST_REPO_ID, "org.apache.maven", ALL ) );
- assertEquals( Collections.<String>emptyList(),
- storage.listProjects( TEST_REPO_ID, "org.apache.maven.plugins", ALL ) );
- assertEquals( Arrays.asList( "maven-downloader", "maven-shared-components" ),
- storage.listProjects( TEST_REPO_ID, "org.apache.maven.shared", ALL ) );
- }
-
- @Test
- public void testGetProjectVersions()
- throws Exception
- {
- assertEquals( Arrays.asList( "1.0-SNAPSHOT" ),
- storage.listProjectVersions( TEST_REPO_ID, "com.example.test", "incomplete-metadata", ALL ) );
- assertEquals( Arrays.asList( "1.0-SNAPSHOT" ),
- storage.listProjectVersions( TEST_REPO_ID, "com.example.test", "malformed-metadata", ALL ) );
- assertEquals( Arrays.asList( "1.0-SNAPSHOT" ),
- storage.listProjectVersions( TEST_REPO_ID, "com.example.test", "missing-metadata", ALL ) );
- assertEquals( Arrays.asList( "1.0" ),
- storage.listProjectVersions( TEST_REPO_ID, "com.example.test", "invalid-pom", ALL ) );
-
- assertEquals( Arrays.asList( "4", "5-SNAPSHOT", "7" ),
- storage.listProjectVersions( TEST_REPO_ID, "org.apache", "apache", ALL ) );
-
- assertEquals( Arrays.asList( "1.2.1", "1.2.2" ),
- storage.listProjectVersions( TEST_REPO_ID, "org.apache.archiva", "archiva", ALL ) );
- assertEquals( Arrays.asList( "1.2.1" ),
- storage.listProjectVersions( TEST_REPO_ID, "org.apache.archiva", "archiva-base", ALL ) );
- assertEquals( Arrays.asList( "1.2.1" ),
- storage.listProjectVersions( TEST_REPO_ID, "org.apache.archiva", "archiva-common", ALL ) );
- assertEquals( Arrays.asList( "1.2.1" ),
- storage.listProjectVersions( TEST_REPO_ID, "org.apache.archiva", "archiva-modules", ALL ) );
- assertEquals( Arrays.asList( "3" ),
- storage.listProjectVersions( TEST_REPO_ID, "org.apache.archiva", "archiva-parent", ALL ) );
-
- assertEquals( Collections.<String>emptyList(),
- storage.listProjectVersions( TEST_REPO_ID, "org.apache.maven.shared", "maven-downloader", ALL ) );
- }
-
- @Test
- public void testGetArtifacts()
- throws Exception
- {
- List<ArtifactMetadata> artifacts = new ArrayList<>( storage.readArtifactsMetadata(
- new ReadMetadataRequest( TEST_REPO_ID, "org.codehaus.plexus", "plexus-spring", "1.2", ALL ) ) );
- assertEquals( 3, artifacts.size() );
- Collections.sort( artifacts, new Comparator<ArtifactMetadata>()
- {
- @Override
- public int compare( ArtifactMetadata o1, ArtifactMetadata o2 )
- {
- return o1.getId().compareTo( o2.getId() );
- }
- } );
-
- assertArtifact( artifacts.get( 0 ), "plexus-spring-1.2-sources.jar", 0, EMPTY_SHA1, EMPTY_MD5 );
- assertArtifact( artifacts.get( 1 ), "plexus-spring-1.2.jar", 0, EMPTY_SHA1, EMPTY_MD5 );
- assertArtifact( artifacts.get( 2 ), "plexus-spring-1.2.pom", 7273, "ac54312a724733a2eb7a9db1a5b8a0ec7671a814",
- "38aa7a946d1ee14fae9bf6a17c603eb8" );
- }
-
- @Test
- public void testGetArtifactsFiltered()
- throws Exception
- {
- ExcludesFilter<String> filter =
- new ExcludesFilter<String>( Collections.singletonList( "plexus-spring-1.2.pom" ) );
- List<ArtifactMetadata> artifacts = new ArrayList<>( storage.readArtifactsMetadata(
- new ReadMetadataRequest( TEST_REPO_ID, "org.codehaus.plexus", "plexus-spring", "1.2", filter ) ) );
- assertEquals( 2, artifacts.size() );
- Collections.sort( artifacts, new Comparator<ArtifactMetadata>()
- {
- @Override
- public int compare( ArtifactMetadata o1, ArtifactMetadata o2 )
- {
- return o1.getId().compareTo( o2.getId() );
- }
- } );
-
- assertArtifact( artifacts.get( 0 ), "plexus-spring-1.2-sources.jar", 0, EMPTY_SHA1, EMPTY_MD5 );
- assertArtifact( artifacts.get( 1 ), "plexus-spring-1.2.jar", 0, EMPTY_SHA1, EMPTY_MD5 );
- }
-
- @Test
- public void testGetArtifactsTimestampedSnapshots()
- throws Exception
- {
- List<ArtifactMetadata> artifacts = new ArrayList<ArtifactMetadata>( storage.readArtifactsMetadata(
- new ReadMetadataRequest( TEST_REPO_ID, "com.example.test", "missing-metadata", "1.0-SNAPSHOT", ALL ) ) );
- assertEquals( 1, artifacts.size() );
-
- ArtifactMetadata artifact = artifacts.get( 0 );
- assertEquals( "missing-metadata-1.0-20091101.112233-1.pom", artifact.getId() );
- assertEquals( "com.example.test", artifact.getNamespace() );
- assertEquals( "missing-metadata", artifact.getProject() );
- assertEquals( "1.0-20091101.112233-1", artifact.getVersion() );
- assertEquals( TEST_REPO_ID, artifact.getRepositoryId() );
- }
-
- private void assertArtifact( ArtifactMetadata artifact, String id, int size, String sha1, String md5 )
- {
- assertEquals( id, artifact.getId() );
- assertEquals( md5, artifact.getMd5() );
- assertEquals( sha1, artifact.getSha1() );
- assertEquals( size, artifact.getSize() );
- assertEquals( "org.codehaus.plexus", artifact.getNamespace() );
- assertEquals( "plexus-spring", artifact.getProject() );
- assertEquals( "1.2", artifact.getVersion() );
- assertEquals( TEST_REPO_ID, artifact.getRepositoryId() );
- }
-
- private void assertMailingList( MailingList mailingList, String name, String archive, String post, String subscribe,
- String unsubscribe, List<String> otherArchives, boolean allowPost )
- {
- assertEquals( archive, mailingList.getMainArchiveUrl() );
- if ( allowPost )
- {
- assertEquals( post, mailingList.getPostAddress() );
- }
- else
- {
- assertNull( mailingList.getPostAddress() );
- }
- assertEquals( subscribe, mailingList.getSubscribeAddress() );
- assertEquals( unsubscribe, mailingList.getUnsubscribeAddress() );
- assertEquals( name, mailingList.getName() );
- assertEquals( otherArchives, mailingList.getOtherArchives() );
- }
-
- private void assertMailingList( String prefix, MailingList mailingList, String name, boolean allowPost,
- String nabbleUrl )
- {
- List<String> otherArchives = new ArrayList<>();
- otherArchives.add( "http://www.mail-archive.com/" + prefix + "@archiva.apache.org" );
- if ( nabbleUrl != null )
- {
- otherArchives.add( nabbleUrl );
- }
- otherArchives.add( "http://markmail.org/list/org.apache.archiva." + prefix );
- assertMailingList( mailingList, name, "http://mail-archives.apache.org/mod_mbox/archiva-" + prefix + "/",
- prefix + "@archiva.apache.org", prefix + "-subscribe@archiva.apache.org",
- prefix + "-unsubscribe@archiva.apache.org", otherArchives, allowPost );
- }
-
- private void checkApacheLicense( ProjectVersionMetadata metadata )
- {
- assertEquals( Arrays.asList( new License( "The Apache Software License, Version 2.0",
- "http://www.apache.org/licenses/LICENSE-2.0.txt" ) ),
- metadata.getLicenses() );
- }
-
- private void checkOrganizationApache( ProjectVersionMetadata metadata )
- {
- assertEquals( "The Apache Software Foundation", metadata.getOrganization().getName() );
- assertEquals( "http://www.apache.org/", metadata.getOrganization().getUrl() );
- }
-
- private void deleteTestArtifactWithParent( List<String> pathsToBeDeleted )
- throws IOException
- {
- for ( String path : pathsToBeDeleted )
- {
- Path dir = Paths.get( org.apache.archiva.common.utils.FileUtils.getBasedir(), path );
- org.apache.archiva.common.utils.FileUtils.deleteDirectory( dir );
-
- assertFalse( Files.exists(dir) );
- }
- Path dest = Paths.get( org.apache.archiva.common.utils.FileUtils.getBasedir(), "target/test-repository/com/example/test/test-artifact-module-a" );
- Path parentPom =
- Paths.get( org.apache.archiva.common.utils.FileUtils.getBasedir(), "target/test-repository/com/example/test/test-artifact-parent" );
- Path rootPom = Paths.get( org.apache.archiva.common.utils.FileUtils.getBasedir(), "target/test-repository/com/example/test/test-artifact-root" );
-
- org.apache.archiva.common.utils.FileUtils.deleteDirectory( dest );
- org.apache.archiva.common.utils.FileUtils.deleteDirectory( parentPom );
- org.apache.archiva.common.utils.FileUtils.deleteDirectory( rootPom );
-
- assertFalse( Files.exists(dest) );
- assertFalse( Files.exists(parentPom) );
- assertFalse( Files.exists(rootPom) );
- }
-
- private Path copyTestArtifactWithParent( String srcPath, String destPath )
- throws IOException
- {
- Path src = Paths.get( org.apache.archiva.common.utils.FileUtils.getBasedir(), srcPath );
- Path dest = Paths.get( org.apache.archiva.common.utils.FileUtils.getBasedir(), destPath );
-
- FileUtils.copyDirectory( src.toFile(), dest.toFile() );
- assertTrue( Files.exists(dest) );
- return dest;
- }
-
- }
|