123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691 |
- package org.apache.archiva.repository.maven.metadata;
-
- /*
- * 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 org.apache.archiva.common.utils.VersionComparator;
- import org.apache.archiva.configuration.ProxyConnectorConfiguration;
- import org.apache.archiva.policies.CachedFailuresPolicy;
- import org.apache.archiva.policies.ChecksumPolicy;
- import org.apache.archiva.policies.ReleasesPolicy;
- import org.apache.archiva.policies.SnapshotsPolicy;
- import org.apache.archiva.repository.ManagedRepositoryContent;
- import org.apache.archiva.repository.RemoteRepositoryContent;
- import org.apache.archiva.repository.RepositoryContentProvider;
- import org.apache.archiva.repository.content.ItemSelector;
- import org.apache.archiva.repository.content.LayoutException;
- import org.apache.archiva.repository.content.base.ArchivaItemSelector;
- import org.apache.archiva.repository.maven.AbstractRepositoryLayerTestCase;
- import org.apache.archiva.repository.maven.MavenManagedRepository;
- import org.apache.archiva.repository.maven.metadata.storage.mock.MockConfiguration;
- import org.apache.archiva.repository.metadata.RepositoryMetadataException;
- import org.apache.archiva.repository.metadata.base.MetadataTools;
- import org.apache.commons.io.FileUtils;
- import org.apache.commons.lang3.StringUtils;
- import org.junit.Test;
- import org.springframework.test.context.ContextConfiguration;
- import org.xml.sax.SAXException;
- import org.xmlunit.builder.DiffBuilder;
- import org.xmlunit.diff.Diff;
- import org.xmlunit.diff.Difference;
-
- import javax.inject.Inject;
- import javax.inject.Named;
- import javax.xml.parsers.ParserConfigurationException;
- import java.io.IOException;
- import java.net.URISyntaxException;
- import java.nio.charset.Charset;
- import java.nio.file.Files;
- import java.nio.file.Path;
- import java.nio.file.Paths;
- import java.util.ArrayList;
- import java.util.Collections;
- import java.util.List;
- import java.util.Set;
-
- import static org.junit.Assert.*;
-
- /**
- * MetadataToolsTest
- */
- @SuppressWarnings( "deprecation" )
- @ContextConfiguration (
- { "classpath*:/META-INF/spring-context.xml", "classpath:/spring-context-metadata-tools-test.xml" } )
- public class MetadataToolsTest
- extends AbstractRepositoryLayerTestCase
- {
- @Inject
- @Named ( "metadataTools#test" )
- private MetadataTools tools;
-
- @Inject
- @Named ( "archivaConfiguration#mock" )
- protected MockConfiguration config;
-
- private Path getRepositoryPath(String repoName) {
- try
- {
- return Paths.get( Thread.currentThread( ).getContextClassLoader( ).getResource( "repositories/" + repoName ).toURI( ) );
- }
- catch ( URISyntaxException e )
- {
- throw new RuntimeException( "Could not resolve repository path " + e.getMessage( ), e );
- }
- }
-
- @Test
- public void testGatherSnapshotVersionsA()
- throws Exception
- {
- removeProxyConnector( "test-repo", "apache-snapshots" );
- removeProxyConnector( "test-repo", "internal-snapshots" );
- removeProxyConnector( "test-repo", "snapshots.codehaus.org" );
-
- assertSnapshotVersions( "snap_shots_a", "1.0-alpha-11-SNAPSHOT",
- new String[]{ "1.0-alpha-11-SNAPSHOT", "1.0-alpha-11-20070221.194724-2",
- "1.0-alpha-11-20070302.212723-3", "1.0-alpha-11-20070303.152828-4",
- "1.0-alpha-11-20070305.215149-5", "1.0-alpha-11-20070307.170909-6",
- "1.0-alpha-11-20070314.211405-9", "1.0-alpha-11-20070316.175232-11" } );
- }
-
- @Test
- public void testGatherSnapshotVersionsAWithProxies()
- throws Exception
- {
- // These proxied repositories do not need to exist for the purposes of this unit test,
- // just the repository ids are important.
- createProxyConnector( "test-repo", "apache-snapshots" );
- createProxyConnector( "test-repo", "internal-snapshots" );
- createProxyConnector( "test-repo", "snapshots.codehaus.org" );
-
- assertSnapshotVersions( "snap_shots_a", "1.0-alpha-11-SNAPSHOT",
- new String[]{ "1.0-alpha-11-SNAPSHOT", "1.0-alpha-11-20070221.194724-2",
- "1.0-alpha-11-20070302.212723-3", "1.0-alpha-11-20070303.152828-4",
- "1.0-alpha-11-20070305.215149-5", "1.0-alpha-11-20070307.170909-6",
- "1.0-alpha-11-20070314.211405-9", "1.0-alpha-11-20070315.033030-10"
- /* Arrives in via snapshots.codehaus.org proxy */,
- "1.0-alpha-11-20070316.175232-11" } );
- }
-
- @Test
- public void testGetRepositorySpecificName()
- throws Exception
- {
- RemoteRepositoryContent repoJavaNet =
- createRemoteRepositoryContent( "maven2-repository.dev.java.net", "Java.net Repository for Maven 2",
- "http://download.java.net/maven/2/", "default" );
- RemoteRepositoryContent repoCentral =
- createRemoteRepositoryContent( "central", "Central Global Repository", "http://repo1.maven.org/maven2/",
- "default" );
-
- String convertedName =
- tools.getRepositorySpecificName( repoJavaNet, "commons-lang/commons-lang/maven-metadata.xml" );
- assertMetadataPath( "commons-lang/commons-lang/maven-metadata-maven2-repository.dev.java.net.xml",
- convertedName );
-
- convertedName = tools.getRepositorySpecificName( repoCentral, "commons-lang/commons-lang/maven-metadata.xml" );
- assertMetadataPath( "commons-lang/commons-lang/maven-metadata-central.xml", convertedName );
- }
-
- // TODO: replace with group tests
- // public void testUpdateProjectBadArtifact()
- // throws Exception
- // {
- // try
- // {
- // assertUpdatedProjectMetadata( "bad_artifact", null );
- // fail( "Should have thrown an IOException on a bad artifact." );
- // }
- // catch ( IOException e )
- // {
- // // Expected path
- // }
- // }
-
- @Test
- public void testUpdateProjectNonExistingVersion()
- throws Exception
- {
- ManagedRepositoryContent testRepo = createTestRepoContent();
- ItemSelector reference = ArchivaItemSelector.builder()
- .withNamespace( "org.apache.archiva.metadata.tests" )
- .withProjectId( "missing_artifact" ).build();
-
- prepProjectTestRepo( testRepo, reference );
-
- // check metadata prior to update -- should contain the non-existing artifact version
- assertProjectMetadata( testRepo, reference, "missing_artifact",
- new String[]{ "1.0-SNAPSHOT", "1.1-SNAPSHOT", "1.2-SNAPSHOT" }, "1.2-SNAPSHOT", null );
-
- tools.updateProjectMetadata( testRepo, reference );
-
- // metadata should not contain the non-existing artifact version -- 1.1-SNAPSHOT
- assertProjectMetadata( testRepo, reference, "missing_artifact", new String[]{ "1.0-SNAPSHOT", "1.2-SNAPSHOT" },
- "1.2-SNAPSHOT", null );
- }
-
- @Test
- public void testUpdateProjectMissingMultipleVersions()
- throws Exception
- {
- assertUpdatedProjectMetadata( "missing_metadata_b",
- new String[]{ "1.0", "1.0.1", "2.0", "2.0.1", "2.0-20070821-dev" },
- "2.0-20070821-dev", "2.0-20070821-dev" );
- }
-
- @Test
- public void testUpdateProjectMissingMultipleVersionsWithProxies()
- throws Exception
- {
- // Attach the (bogus) proxies to the managed repo.
- // These proxied repositories do not need to exist for the purposes of this unit test,
- // just the repository ids are important.
- createProxyConnector( "test-repo", "central" );
- createProxyConnector( "test-repo", "java.net" );
-
- assertUpdatedProjectMetadata( "proxied_multi",
- new String[]{ "1.0-spec" /* in java.net */, "1.0" /* in managed, and central */,
- "1.0.1" /* in central */, "1.1" /* in managed */, "2.0-proposal-beta"
- /* in java.net */, "2.0-spec" /* in java.net */, "2.0"
- /* in central, and java.net */, "2.0.1" /* in java.net */, "2.1"
- /* in managed */, "3.0" /* in central */, "3.1" /* in central */ }, "3.1",
- "3.1" );
- }
-
- @Test
- public void testUpdateProjectSimpleYetIncomplete()
- throws Exception
- {
- assertUpdatedProjectMetadata( "incomplete_metadata_a", new String[]{ "1.0" }, "1.0", "1.0" );
- }
-
- @Test
- public void testUpdateProjectSimpleYetMissing()
- throws Exception
- {
- assertUpdatedProjectMetadata( "missing_metadata_a", new String[]{ "1.0" }, "1.0", "1.0" );
- }
-
- @Test
- public void testUpdateVersionSimple10()
- throws Exception
- {
- assertUpdatedReleaseVersionMetadata( "missing_metadata_a", "1.0" );
- }
-
- @Test
- public void testUpdateVersionSimple20()
- throws Exception
- {
- assertUpdatedReleaseVersionMetadata( "missing_metadata_b", "2.0" );
- }
-
- @Test
- public void testUpdateVersionSimple20NotSnapshot()
- throws Exception
- {
- assertUpdatedReleaseVersionMetadata( "missing_metadata_b", "2.0-20070821-dev" );
- }
-
- @Test
- public void testUpdateVersionSnapshotA()
- throws Exception
- {
- assertUpdatedSnapshotVersionMetadata( "snap_shots_a", "1.0-alpha-11-SNAPSHOT", "20070316", "175232", "11" );
- }
-
- @Test
- public void testToPathFromVersionReference()
- {
- ItemSelector selector = ArchivaItemSelector.builder( )
- .withNamespace( "com.foo" )
- .withArtifactId( "foo-tool" )
- .withProjectId( "foo-tool" )
- .withVersion( "1.0" ).build( );
-
- assertEquals( "com/foo/foo-tool/1.0/maven-metadata.xml", tools.toPath( selector ) );
- }
-
- @Test
- public void testToPathFromProjectReference()
- {
- ItemSelector selector = ArchivaItemSelector.builder( )
- .withNamespace( "com.foo" )
- .withProjectId( "foo-tool" )
- .withArtifactId( "foo-tool" ).build( );
-
- assertEquals( "com/foo/foo-tool/maven-metadata.xml", tools.toPath( selector ) );
- }
-
- @Test
- public void testToProjectReferenceFooTools()
- throws RepositoryMetadataException
- {
- assertProjectReference( "com.foo", "foo-tools", "com/foo/foo-tools/maven-metadata.xml" );
- }
-
- @Test
- public void testToProjectReferenceAReallyLongPath()
- throws RepositoryMetadataException
- {
- String groupId = "net.i.have.a.really.long.path.just.for.the.hell.of.it";
- String artifactId = "a";
- String path = "net/i/have/a/really/long/path/just/for/the/hell/of/it/a/maven-metadata.xml";
-
- assertProjectReference( groupId, artifactId, path );
- }
-
- @Test
- public void testToProjectReferenceCommonsLang()
- throws RepositoryMetadataException
- {
- String groupId = "commons-lang";
- String artifactId = "commons-lang";
- String path = "commons-lang/commons-lang/maven-metadata.xml";
-
- assertProjectReference( groupId, artifactId, path );
- }
-
- private void assertProjectReference( String groupId, String artifactId, String path )
- throws RepositoryMetadataException
- {
- ItemSelector reference = tools.toProjectSelector( path );
-
- assertNotNull( "Reference should not be null.", reference );
- assertEquals( "ProjectReference.groupId", groupId, reference.getNamespace() );
- assertEquals( "ProjectReference.artifactId", artifactId, reference.getArtifactId() );
- }
-
- @Test
- public void testToVersionedReferenceFooTool()
- throws RepositoryMetadataException
- {
- String groupId = "com.foo";
- String artifactId = "foo-tool";
- String version = "1.0";
- String path = "com/foo/foo-tool/1.0/maven-metadata.xml";
-
- assertVersionedReference( groupId, artifactId, version, path );
- }
-
- @Test
- public void testToVersionedReferenceAReallyLongPath()
- throws RepositoryMetadataException
- {
- String groupId = "net.i.have.a.really.long.path.just.for.the.hell.of.it";
- String artifactId = "a";
- String version = "1.1-alpha-1";
- String path = "net/i/have/a/really/long/path/just/for/the/hell/of/it/a/1.1-alpha-1/maven-metadata.xml";
-
- assertVersionedReference( groupId, artifactId, version, path );
- }
-
- @Test
- public void testToVersionedReferenceCommonsLang()
- throws RepositoryMetadataException
- {
- String groupId = "commons-lang";
- String artifactId = "commons-lang";
- String version = "2.1";
- String path = "commons-lang/commons-lang/2.1/maven-metadata.xml";
-
- assertVersionedReference( groupId, artifactId, version, path );
- }
-
- @Test
- public void testToVersionedReferenceSnapshot()
- throws RepositoryMetadataException
- {
- String groupId = "com.foo";
- String artifactId = "foo-connector";
- String version = "2.1-SNAPSHOT";
- String path = "com/foo/foo-connector/2.1-SNAPSHOT/maven-metadata.xml";
-
- assertVersionedReference( groupId, artifactId, version, path );
- }
-
- private void assertVersionedReference( String groupId, String artifactId, String version, String path )
- throws RepositoryMetadataException
- {
- ItemSelector reference = tools.toVersionedSelector( path );
- assertNotNull( "Reference should not be null.", reference );
-
- assertEquals( "VersionedReference.groupId", groupId, reference.getNamespace() );
- assertEquals( "VersionedReference.artifactId", artifactId, reference.getArtifactId() );
- assertEquals( "VersionedReference.version", version, reference.getVersion() );
- }
-
- private void assertSnapshotVersions( String artifactId, String version, String[] expectedVersions )
- throws Exception
- {
- Path repoRootDir = getRepositoryPath( "metadata-repository" );
-
- ItemSelector reference = ArchivaItemSelector.builder( )
- .withNamespace( "org.apache.archiva.metadata.tests" )
- .withArtifactId( artifactId )
- .withProjectId( artifactId )
- .withVersion( version ).build( );
-
- MavenManagedRepository repo =
- createRepository( "test-repo", "Test Repository: " + name.getMethodName(), repoRootDir );
-
- RepositoryContentProvider provider = applicationContext.getBean( "repositoryContentProvider#maven", RepositoryContentProvider.class );
-
- ManagedRepositoryContent repoContent =
- provider.createManagedContent( repo );
-
- Set<String> testedVersionSet = tools.gatherSnapshotVersions( repoContent, reference );
-
- // Sort the list (for asserts)
- List<String> testedVersions = new ArrayList<>();
- testedVersions.addAll( testedVersionSet );
- Collections.sort( testedVersions, new VersionComparator() );
-
- // Test the expected array of versions, to the actual tested versions
- assertEquals( "Assert Snapshot Versions: length/size", expectedVersions.length, testedVersions.size() );
-
- for ( int i = 0; i < expectedVersions.length; i++ )
- {
- String actualVersion = testedVersions.get( i );
- assertEquals( "Snapshot Versions[" + i + "]", expectedVersions[i], actualVersion );
- }
- }
-
- private void assertProjectMetadata( String expectedMetadata, ManagedRepositoryContent repository,
- ItemSelector reference )
- throws LayoutException, IOException, SAXException, ParserConfigurationException
- {
- Path metadataFile = repository.getRepository().getRoot().getFilePath().resolve(tools.toPath( reference ) );
- String actualMetadata = org.apache.archiva.common.utils.FileUtils.readFileToString( metadataFile, Charset.defaultCharset() );
-
- Diff detailedDiff = DiffBuilder.compare( expectedMetadata ).withTest( actualMetadata ).checkForSimilar().build();
- if ( detailedDiff.hasDifferences() )
- {
- for ( Difference diff : detailedDiff.getDifferences() ) {
- System.out.println( diff );
- }
- // If it isn't similar, dump the difference.
- assertEquals( expectedMetadata, actualMetadata );
- }
- }
-
- private void assertMetadata( String expectedMetadata, ManagedRepositoryContent repository,
- ItemSelector reference )
- throws LayoutException, IOException, SAXException, ParserConfigurationException
- {
- Path metadataFile = repository.getRepository().getRoot().getFilePath().resolve( tools.toPath( reference ) );
- String actualMetadata = org.apache.archiva.common.utils.FileUtils.readFileToString( metadataFile, Charset.defaultCharset() );
-
- Diff detailedDiff = DiffBuilder.compare( expectedMetadata ).withTest( actualMetadata ).checkForSimilar().build();
- if ( detailedDiff.hasDifferences() )
- {
- for ( Difference diff : detailedDiff.getDifferences() ) {
- System.out.println( diff );
- }
- // If it isn't similar, dump the difference.
- assertEquals( expectedMetadata, actualMetadata );
- }
- }
-
- private void assertMetadataPath( String expected, String actual )
- {
- assertEquals( "Repository Specific Metadata Path", expected, actual );
- }
-
- private void assertUpdatedProjectMetadata( String artifactId, String[] expectedVersions, String latestVersion,
- String releaseVersion )
- throws Exception
- {
- ManagedRepositoryContent testRepo = createTestRepoContent();
- ItemSelector reference = ArchivaItemSelector.builder( )
- .withNamespace( "org.apache.archiva.metadata.tests" )
- .withProjectId( artifactId ).build();
-
- prepProjectTestRepo( testRepo, reference );
-
- tools.updateProjectMetadata( testRepo, reference );
-
- StringBuilder buf = new StringBuilder();
- buf.append( "<metadata>\n" );
- buf.append( " <groupId>" ).append( reference.getNamespace() ).append( "</groupId>\n" );
- buf.append( " <artifactId>" ).append( reference.getProjectId() ).append( "</artifactId>\n" );
- // buf.append( " <version>1.0</version>\n" );
-
- if ( expectedVersions != null )
- {
- buf.append( " <versioning>\n" );
- if ( latestVersion != null )
- {
- buf.append( " <latest>" ).append( latestVersion ).append( "</latest>\n" );
- }
- if ( releaseVersion != null )
- {
- buf.append( " <release>" ).append( releaseVersion ).append( "</release>\n" );
- }
-
- buf.append( " <versions>\n" );
- for ( int i = 0; i < expectedVersions.length; i++ )
- {
- buf.append( " <version>" ).append( expectedVersions[i] ).append( "</version>\n" );
- }
- buf.append( " </versions>\n" );
- buf.append( " </versioning>\n" );
- }
- buf.append( "</metadata>" );
-
- assertProjectMetadata( buf.toString(), testRepo, reference );
- }
-
- private void assertProjectMetadata( ManagedRepositoryContent testRepo, ItemSelector reference,
- String artifactId, String[] expectedVersions, String latestVersion,
- String releaseVersion )
- throws Exception
- {
- StringBuilder buf = new StringBuilder();
- buf.append( "<metadata>\n" );
- buf.append( " <groupId>" ).append( reference.getNamespace() ).append( "</groupId>\n" );
- buf.append( " <artifactId>" ).append( reference.getProjectId() ).append( "</artifactId>\n" );
-
- if ( expectedVersions != null )
- {
- buf.append( " <versioning>\n" );
- if ( latestVersion != null )
- {
- buf.append( " <latest>" ).append( latestVersion ).append( "</latest>\n" );
- }
- if ( releaseVersion != null )
- {
- buf.append( " <release>" ).append( releaseVersion ).append( "</release>\n" );
- }
-
- buf.append( " <versions>\n" );
- for ( int i = 0; i < expectedVersions.length; i++ )
- {
- buf.append( " <version>" ).append( expectedVersions[i] ).append( "</version>\n" );
- }
- buf.append( " </versions>\n" );
- buf.append( " </versioning>\n" );
- }
- buf.append( "</metadata>" );
-
- assertProjectMetadata( buf.toString(), testRepo, reference );
- }
-
-
- private void assertUpdatedReleaseVersionMetadata( String artifactId, String version )
- throws Exception
- {
- ManagedRepositoryContent testRepo = createTestRepoContent();
-
- ItemSelector selector = ArchivaItemSelector.builder()
- .withNamespace( "org.apache.archiva.metadata.tests" )
- .withProjectId( artifactId )
- .withArtifactId( artifactId )
- .withVersion( version ).build();
-
- prepTestRepo( testRepo, selector );
-
- tools.updateVersionMetadata( testRepo, selector );
-
- StringBuilder buf = new StringBuilder();
- buf.append( "<metadata>\n" );
- buf.append( " <groupId>" ).append( selector.getNamespace() ).append( "</groupId>\n" );
- buf.append( " <artifactId>" ).append( selector.getArtifactId() ).append( "</artifactId>\n" );
- buf.append( " <version>" ).append( selector.getVersion() ).append( "</version>\n" );
- buf.append( "</metadata>" );
-
- assertMetadata( buf.toString(), testRepo, selector );
- }
-
- private void assertUpdatedSnapshotVersionMetadata( String artifactId, String version, String expectedDate,
- String expectedTime, String expectedBuildNumber )
- throws Exception
- {
- ManagedRepositoryContent testRepo = createTestRepoContent();
- ItemSelector reference = ArchivaItemSelector.builder()
- .withNamespace( "org.apache.archiva.metadata.tests" )
- .withArtifactId( artifactId )
- .withProjectId( artifactId )
- .withVersion( version ).build();
-
- prepTestRepo( testRepo, reference );
-
- tools.updateVersionMetadata( testRepo, reference );
-
- StringBuilder buf = new StringBuilder();
- buf.append( "<metadata>\n" );
- buf.append( " <groupId>" ).append( reference.getNamespace() ).append( "</groupId>\n" );
- buf.append( " <artifactId>" ).append( reference.getArtifactId() ).append( "</artifactId>\n" );
- buf.append( " <version>" ).append( reference.getVersion() ).append( "</version>\n" );
- buf.append( " <versioning>\n" );
- buf.append( " <snapshot>\n" );
- buf.append( " <buildNumber>" ).append( expectedBuildNumber ).append( "</buildNumber>\n" );
- buf.append( " <timestamp>" );
- buf.append( expectedDate ).append( "." ).append( expectedTime );
- buf.append( "</timestamp>\n" );
- buf.append( " </snapshot>\n" );
- buf.append( " <lastUpdated>" ).append( expectedDate ).append( expectedTime ).append( "</lastUpdated>\n" );
- buf.append( " </versioning>\n" );
- buf.append( "</metadata>" );
-
- assertMetadata( buf.toString(), testRepo, reference );
- }
-
- private void removeProxyConnector( String sourceRepoId, String targetRepoId )
- {
- ProxyConnectorConfiguration toRemove = null;
- for ( ProxyConnectorConfiguration pcc : config.getConfiguration().getProxyConnectors() )
- {
- if ( pcc.getTargetRepoId().equals( targetRepoId ) && pcc.getSourceRepoId().equals( sourceRepoId ) )
- {
- toRemove = pcc;
- }
- }
- if ( toRemove != null )
- {
- config.getConfiguration().removeProxyConnector( toRemove );
- String prefix = "proxyConnectors.proxyConnector(" + "1" + ")"; // XXX
- config.triggerChange( prefix + ".sourceRepoId", toRemove.getSourceRepoId() );
- config.triggerChange( prefix + ".targetRepoId", toRemove.getTargetRepoId() );
- config.triggerChange( prefix + ".proxyId", toRemove.getProxyId() );
- config.triggerChange( prefix + ".policies.releases", toRemove.getPolicy( "releases", "" ) );
- config.triggerChange( prefix + ".policies.checksum", toRemove.getPolicy( "checksum", "" ) );
- config.triggerChange( prefix + ".policies.snapshots", toRemove.getPolicy( "snapshots", "" ) );
- config.triggerChange( prefix + ".policies.cache-failures", toRemove.getPolicy( "cache-failures", "" ) );
- }
- }
-
- private void createProxyConnector( String sourceRepoId, String targetRepoId )
- {
- ProxyConnectorConfiguration connectorConfig = new ProxyConnectorConfiguration();
- connectorConfig.setSourceRepoId( sourceRepoId );
- connectorConfig.setTargetRepoId( targetRepoId );
- connectorConfig.addPolicy( ProxyConnectorConfiguration.POLICY_CHECKSUM, ChecksumPolicy.IGNORE.getId() );
- connectorConfig.addPolicy( ProxyConnectorConfiguration.POLICY_RELEASES, ReleasesPolicy.ALWAYS.getId() );
- connectorConfig.addPolicy( ProxyConnectorConfiguration.POLICY_SNAPSHOTS, SnapshotsPolicy.ALWAYS.getId() );
- connectorConfig.addPolicy( ProxyConnectorConfiguration.POLICY_CACHE_FAILURES, CachedFailuresPolicy.NO.getId() );
-
- int count = config.getConfiguration().getProxyConnectors().size();
- config.getConfiguration().addProxyConnector( connectorConfig );
-
- // Proper Triggering ...
- String prefix = "proxyConnectors.proxyConnector(" + count + ")";
- config.triggerChange( prefix + ".sourceRepoId", connectorConfig.getSourceRepoId() );
- config.triggerChange( prefix + ".targetRepoId", connectorConfig.getTargetRepoId() );
- config.triggerChange( prefix + ".proxyId", connectorConfig.getProxyId() );
- config.triggerChange( prefix + ".policies.releases", connectorConfig.getPolicy( "releases", "" ) );
- config.triggerChange( prefix + ".policies.checksum", connectorConfig.getPolicy( "checksum", "" ) );
- config.triggerChange( prefix + ".policies.snapshots", connectorConfig.getPolicy( "snapshots", "" ) );
- config.triggerChange( prefix + ".policies.cache-failures", connectorConfig.getPolicy( "cache-failures", "" ) );
- }
-
- private ManagedRepositoryContent createTestRepoContent()
- throws Exception
- {
- Path repoRoot = Paths.get( "target/metadata-tests/" + name.getMethodName() );
- if ( Files.exists(repoRoot) )
- {
- org.apache.archiva.common.utils.FileUtils.deleteDirectory( repoRoot );
- }
-
- Files.createDirectories(repoRoot);
-
- MavenManagedRepository repoConfig =
- createRepository( "test-repo", "Test Repository: " + name.getMethodName(), repoRoot );
-
- RepositoryContentProvider provider = applicationContext.getBean( "repositoryContentProvider#maven", RepositoryContentProvider.class );
-
- ManagedRepositoryContent repoContent =
- provider.createManagedContent( repoConfig );
- return repoContent;
- }
-
- private void prepProjectTestRepo( ManagedRepositoryContent repo, ItemSelector reference)
- throws IOException
- {
- String groupDir = StringUtils.replaceChars( reference.getNamespace(), '.', '/' );
- String path = groupDir + "/" + reference.getArtifactId();
-
- Path srcRepoDir = getRepositoryPath( "metadata-repository" );
- Path srcDir = srcRepoDir.resolve( path );
- Path destDir = repo.getRepository().getRoot().getFilePath().resolve( path );
-
- assertTrue( "Source Dir exists: " + srcDir, Files.exists(srcDir) );
- Files.createDirectories(destDir);
-
- FileUtils.copyDirectory( srcDir.toFile(), destDir.toFile() );
- }
-
- private void prepTestRepo( ManagedRepositoryContent repo, ItemSelector reference )
- throws IOException
- {
- String groupDir = StringUtils.replaceChars( reference.getNamespace(), '.', '/' );
- String path = groupDir + "/" + reference.getArtifactId();
-
- Path srcRepoDir = getRepositoryPath( "metadata-repository" );
- Path srcDir = srcRepoDir.resolve( path );
- Path destDir = repo.getRepository().getRoot().getFilePath().resolve( path );
-
- assertTrue( "Source Dir exists: " + srcDir, Files.exists(srcDir) );
- Files.createDirectories(destDir);
-
- FileUtils.copyDirectory( srcDir.toFile(), destDir.toFile() );
- }
-
-
- }
|