mirror of https://github.com/apache/archiva.git
[MRM-520] Proxy Connectors are not deleted with the deletion of a Repository.
Added ability of delete (managed|remote) repository action to clear out the associated proxy connector. Added tests. git-svn-id: https://svn.apache.org/repos/asf/maven/archiva/trunk@586635 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
e74ebe51b7
commit
8042e19982
|
@ -23,6 +23,7 @@ import org.apache.maven.archiva.configuration.ArchivaConfiguration;
|
||||||
import org.apache.maven.archiva.configuration.Configuration;
|
import org.apache.maven.archiva.configuration.Configuration;
|
||||||
import org.apache.maven.archiva.configuration.IndeterminateConfigurationException;
|
import org.apache.maven.archiva.configuration.IndeterminateConfigurationException;
|
||||||
import org.apache.maven.archiva.configuration.InvalidConfigurationException;
|
import org.apache.maven.archiva.configuration.InvalidConfigurationException;
|
||||||
|
import org.apache.maven.archiva.configuration.ProxyConnectorConfiguration;
|
||||||
import org.apache.maven.archiva.security.ArchivaRoleConstants;
|
import org.apache.maven.archiva.security.ArchivaRoleConstants;
|
||||||
import org.codehaus.plexus.redback.rbac.Resource;
|
import org.codehaus.plexus.redback.rbac.Resource;
|
||||||
import org.codehaus.plexus.redback.xwork.interceptor.SecureAction;
|
import org.codehaus.plexus.redback.xwork.interceptor.SecureAction;
|
||||||
|
@ -32,6 +33,8 @@ import org.codehaus.plexus.registry.RegistryException;
|
||||||
import org.codehaus.plexus.xwork.action.PlexusActionSupport;
|
import org.codehaus.plexus.xwork.action.PlexusActionSupport;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Abstract AdminRepositories Action base.
|
* Abstract AdminRepositories Action base.
|
||||||
|
@ -101,4 +104,14 @@ public abstract class AbstractRepositoriesAdminAction
|
||||||
|
|
||||||
return SUCCESS;
|
return SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the list of ProxyConnectors that are present in the configuration.
|
||||||
|
*
|
||||||
|
* @return a new list of ProxyConnectors present in the configuration.
|
||||||
|
*/
|
||||||
|
protected List<ProxyConnectorConfiguration> getProxyConnectors()
|
||||||
|
{
|
||||||
|
return new ArrayList<ProxyConnectorConfiguration>( archivaConfiguration.getConfiguration().getProxyConnectors() );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,9 +24,11 @@ import com.opensymphony.xwork.Preparable;
|
||||||
import org.apache.commons.lang.StringUtils;
|
import org.apache.commons.lang.StringUtils;
|
||||||
import org.apache.maven.archiva.configuration.Configuration;
|
import org.apache.maven.archiva.configuration.Configuration;
|
||||||
import org.apache.maven.archiva.configuration.ManagedRepositoryConfiguration;
|
import org.apache.maven.archiva.configuration.ManagedRepositoryConfiguration;
|
||||||
|
import org.apache.maven.archiva.configuration.ProxyConnectorConfiguration;
|
||||||
import org.codehaus.plexus.redback.role.RoleManagerException;
|
import org.codehaus.plexus.redback.role.RoleManagerException;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* DeleteManagedRepositoryAction
|
* DeleteManagedRepositoryAction
|
||||||
|
@ -123,7 +125,15 @@ public class DeleteManagedRepositoryAction
|
||||||
|
|
||||||
// TODO: [MRM-265] After removing a managed repository - Browse/Search still see it
|
// TODO: [MRM-265] After removing a managed repository - Browse/Search still see it
|
||||||
|
|
||||||
// TODO: [MRM-520] Proxy Connectors are not deleted with the deletion of a Repository.
|
// [MRM-520] Proxy Connectors are not deleted with the deletion of a Repository.
|
||||||
|
List<ProxyConnectorConfiguration> proxyConnectors = getProxyConnectors();
|
||||||
|
for ( ProxyConnectorConfiguration proxyConnector : proxyConnectors )
|
||||||
|
{
|
||||||
|
if ( StringUtils.equals( proxyConnector.getSourceRepoId(), cleanupRepository.getId() ) )
|
||||||
|
{
|
||||||
|
archivaConfiguration.getConfiguration().removeProxyConnector( proxyConnector );
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public ManagedRepositoryConfiguration getRepository()
|
public ManagedRepositoryConfiguration getRepository()
|
||||||
|
|
|
@ -23,8 +23,11 @@ import com.opensymphony.xwork.Preparable;
|
||||||
|
|
||||||
import org.apache.commons.lang.StringUtils;
|
import org.apache.commons.lang.StringUtils;
|
||||||
import org.apache.maven.archiva.configuration.Configuration;
|
import org.apache.maven.archiva.configuration.Configuration;
|
||||||
|
import org.apache.maven.archiva.configuration.ProxyConnectorConfiguration;
|
||||||
import org.apache.maven.archiva.configuration.RemoteRepositoryConfiguration;
|
import org.apache.maven.archiva.configuration.RemoteRepositoryConfiguration;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* DeleteRemoteRepositoryAction
|
* DeleteRemoteRepositoryAction
|
||||||
*
|
*
|
||||||
|
@ -81,7 +84,16 @@ public class DeleteRemoteRepositoryAction
|
||||||
|
|
||||||
private void cleanupRepositoryData( RemoteRepositoryConfiguration existingRepository )
|
private void cleanupRepositoryData( RemoteRepositoryConfiguration existingRepository )
|
||||||
{
|
{
|
||||||
// TODO: [MRM-520] Proxy Connectors are not deleted with the deletion of a Repository.
|
// [MRM-520] Proxy Connectors are not deleted with the deletion of a Repository.
|
||||||
|
|
||||||
|
List<ProxyConnectorConfiguration> proxyConnectors = getProxyConnectors();
|
||||||
|
for ( ProxyConnectorConfiguration proxyConnector : proxyConnectors )
|
||||||
|
{
|
||||||
|
if ( StringUtils.equals( proxyConnector.getTargetRepoId(), existingRepository.getId() ) )
|
||||||
|
{
|
||||||
|
archivaConfiguration.getConfiguration().removeProxyConnector( proxyConnector );
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public RemoteRepositoryConfiguration getRepository()
|
public RemoteRepositoryConfiguration getRepository()
|
||||||
|
|
|
@ -25,6 +25,8 @@ import org.apache.maven.archiva.configuration.ArchivaConfiguration;
|
||||||
import org.apache.maven.archiva.configuration.Configuration;
|
import org.apache.maven.archiva.configuration.Configuration;
|
||||||
import org.apache.maven.archiva.configuration.IndeterminateConfigurationException;
|
import org.apache.maven.archiva.configuration.IndeterminateConfigurationException;
|
||||||
import org.apache.maven.archiva.configuration.ManagedRepositoryConfiguration;
|
import org.apache.maven.archiva.configuration.ManagedRepositoryConfiguration;
|
||||||
|
import org.apache.maven.archiva.configuration.ProxyConnectorConfiguration;
|
||||||
|
import org.apache.maven.archiva.configuration.RemoteRepositoryConfiguration;
|
||||||
import org.apache.maven.archiva.security.ArchivaRoleConstants;
|
import org.apache.maven.archiva.security.ArchivaRoleConstants;
|
||||||
import org.codehaus.plexus.PlexusTestCase;
|
import org.codehaus.plexus.PlexusTestCase;
|
||||||
import org.codehaus.plexus.redback.role.RoleManager;
|
import org.codehaus.plexus.redback.role.RoleManager;
|
||||||
|
@ -120,7 +122,7 @@ public class DeleteManagedRepositoryActionTest
|
||||||
{
|
{
|
||||||
prepareRoleManagerMock();
|
prepareRoleManagerMock();
|
||||||
|
|
||||||
Configuration configuration = prepDeletionTest( createRepository(), "delete-entry" );
|
Configuration configuration = prepDeletionTest( createRepository(), 3 );
|
||||||
String status = action.deleteEntry();
|
String status = action.deleteEntry();
|
||||||
assertEquals( Action.SUCCESS, status );
|
assertEquals( Action.SUCCESS, status );
|
||||||
|
|
||||||
|
@ -134,7 +136,7 @@ public class DeleteManagedRepositoryActionTest
|
||||||
{
|
{
|
||||||
prepareRoleManagerMock();
|
prepareRoleManagerMock();
|
||||||
|
|
||||||
Configuration configuration = prepDeletionTest( createRepository(), "delete-contents" );
|
Configuration configuration = prepDeletionTest( createRepository(), 3 );
|
||||||
String status = action.deleteContents();
|
String status = action.deleteContents();
|
||||||
assertEquals( Action.SUCCESS, status );
|
assertEquals( Action.SUCCESS, status );
|
||||||
|
|
||||||
|
@ -143,11 +145,32 @@ public class DeleteManagedRepositoryActionTest
|
||||||
assertFalse( location.exists() );
|
assertFalse( location.exists() );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testDeleteRepositoryAndAssociatedProxyConnectors()
|
||||||
|
throws Exception
|
||||||
|
{
|
||||||
|
Configuration configuration = prepDeletionTest( createRepository(), 4 );
|
||||||
|
configuration.addRemoteRepository( createRemoteRepository( "codehaus", "http://repository.codehaus.org" ) );
|
||||||
|
configuration.addRemoteRepository( createRemoteRepository( "java.net", "http://dev.java.net/maven2" ) );
|
||||||
|
configuration.addProxyConnector( createProxyConnector( REPO_ID, "codehaus" ) );
|
||||||
|
|
||||||
|
prepareRoleManagerMock();
|
||||||
|
|
||||||
|
assertEquals( 1, configuration.getProxyConnectors().size() );
|
||||||
|
|
||||||
|
String status = action.deleteContents();
|
||||||
|
assertEquals( Action.SUCCESS, status );
|
||||||
|
|
||||||
|
assertTrue( configuration.getManagedRepositories().isEmpty() );
|
||||||
|
assertEquals( 0, configuration.getProxyConnectors().size() );
|
||||||
|
|
||||||
|
assertFalse( location.exists() );
|
||||||
|
}
|
||||||
|
|
||||||
public void testDeleteRepositoryCancelled()
|
public void testDeleteRepositoryCancelled()
|
||||||
throws Exception
|
throws Exception
|
||||||
{
|
{
|
||||||
ManagedRepositoryConfiguration originalRepository = createRepository();
|
ManagedRepositoryConfiguration originalRepository = createRepository();
|
||||||
Configuration configuration = prepDeletionTest( originalRepository, null );
|
Configuration configuration = prepDeletionTest( originalRepository, 3 );
|
||||||
String status = action.execute();
|
String status = action.execute();
|
||||||
assertEquals( Action.SUCCESS, status );
|
assertEquals( Action.SUCCESS, status );
|
||||||
|
|
||||||
|
@ -158,7 +181,7 @@ public class DeleteManagedRepositoryActionTest
|
||||||
assertTrue( location.exists() );
|
assertTrue( location.exists() );
|
||||||
}
|
}
|
||||||
|
|
||||||
private Configuration prepDeletionTest( ManagedRepositoryConfiguration originalRepository, String mode )
|
private Configuration prepDeletionTest( ManagedRepositoryConfiguration originalRepository, int expectCountGetConfig )
|
||||||
throws RegistryException, IndeterminateConfigurationException
|
throws RegistryException, IndeterminateConfigurationException
|
||||||
{
|
{
|
||||||
location.mkdirs();
|
location.mkdirs();
|
||||||
|
@ -166,9 +189,7 @@ public class DeleteManagedRepositoryActionTest
|
||||||
Configuration configuration = createConfigurationForEditing( originalRepository );
|
Configuration configuration = createConfigurationForEditing( originalRepository );
|
||||||
|
|
||||||
archivaConfiguration.getConfiguration();
|
archivaConfiguration.getConfiguration();
|
||||||
archivaConfigurationControl.setReturnValue( configuration );
|
archivaConfigurationControl.setReturnValue( configuration, expectCountGetConfig );
|
||||||
archivaConfiguration.getConfiguration();
|
|
||||||
archivaConfigurationControl.setReturnValue( configuration );
|
|
||||||
|
|
||||||
archivaConfiguration.save( configuration );
|
archivaConfiguration.save( configuration );
|
||||||
archivaConfigurationControl.replay();
|
archivaConfigurationControl.replay();
|
||||||
|
@ -213,23 +234,36 @@ public class DeleteManagedRepositoryActionTest
|
||||||
{
|
{
|
||||||
ManagedRepositoryConfiguration r = new ManagedRepositoryConfiguration();
|
ManagedRepositoryConfiguration r = new ManagedRepositoryConfiguration();
|
||||||
r.setId( REPO_ID );
|
r.setId( REPO_ID );
|
||||||
populateRepository( r );
|
r.setName( "repo name" );
|
||||||
|
r.setLocation( location.getAbsolutePath() );
|
||||||
|
r.setLayout( "default" );
|
||||||
|
r.setRefreshCronExpression( "* 0/5 * * * ?" );
|
||||||
|
r.setDaysOlder( 0 );
|
||||||
|
r.setRetentionCount( 0 );
|
||||||
|
r.setReleases( true );
|
||||||
|
r.setSnapshots( true );
|
||||||
|
r.setScanned( false );
|
||||||
|
r.setDeleteReleasedSnapshots( false );
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void populateRepository( ManagedRepositoryConfiguration repository )
|
private RemoteRepositoryConfiguration createRemoteRepository(String id, String url)
|
||||||
{
|
{
|
||||||
repository.setId( REPO_ID );
|
RemoteRepositoryConfiguration r = new RemoteRepositoryConfiguration();
|
||||||
repository.setName( "repo name" );
|
r.setId( id );
|
||||||
repository.setLocation( location.getAbsolutePath() );
|
r.setUrl( url );
|
||||||
repository.setLayout( "default" );
|
r.setLayout( "default" );
|
||||||
repository.setRefreshCronExpression( "* 0/5 * * * ?" );
|
|
||||||
repository.setDaysOlder( 31 );
|
return r;
|
||||||
repository.setRetentionCount( 20 );
|
}
|
||||||
repository.setReleases( true );
|
|
||||||
repository.setSnapshots( true );
|
private ProxyConnectorConfiguration createProxyConnector( String managedRepoId, String remoteRepoId )
|
||||||
repository.setScanned( false );
|
{
|
||||||
repository.setDeleteReleasedSnapshots( true );
|
ProxyConnectorConfiguration connector = new ProxyConnectorConfiguration();
|
||||||
|
connector.setSourceRepoId( managedRepoId );
|
||||||
|
connector.setTargetRepoId( remoteRepoId );
|
||||||
|
|
||||||
|
return connector;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void prepareRoleManagerMock()
|
private void prepareRoleManagerMock()
|
||||||
|
|
|
@ -24,6 +24,8 @@ import com.opensymphony.xwork.Action;
|
||||||
import org.apache.maven.archiva.configuration.ArchivaConfiguration;
|
import org.apache.maven.archiva.configuration.ArchivaConfiguration;
|
||||||
import org.apache.maven.archiva.configuration.Configuration;
|
import org.apache.maven.archiva.configuration.Configuration;
|
||||||
import org.apache.maven.archiva.configuration.IndeterminateConfigurationException;
|
import org.apache.maven.archiva.configuration.IndeterminateConfigurationException;
|
||||||
|
import org.apache.maven.archiva.configuration.ManagedRepositoryConfiguration;
|
||||||
|
import org.apache.maven.archiva.configuration.ProxyConnectorConfiguration;
|
||||||
import org.apache.maven.archiva.configuration.RemoteRepositoryConfiguration;
|
import org.apache.maven.archiva.configuration.RemoteRepositoryConfiguration;
|
||||||
import org.codehaus.plexus.PlexusTestCase;
|
import org.codehaus.plexus.PlexusTestCase;
|
||||||
import org.codehaus.plexus.registry.RegistryException;
|
import org.codehaus.plexus.registry.RegistryException;
|
||||||
|
@ -89,11 +91,12 @@ public class DeleteRemoteRepositoryActionTest
|
||||||
throws RegistryException, IndeterminateConfigurationException
|
throws RegistryException, IndeterminateConfigurationException
|
||||||
{
|
{
|
||||||
Configuration configuration = createConfigurationForEditing( createRepository() );
|
Configuration configuration = createConfigurationForEditing( createRepository() );
|
||||||
|
configuration.addManagedRepository( createManagedRepository( "internal", getTestPath( "target/repo/internal" ) ) );
|
||||||
|
configuration.addManagedRepository( createManagedRepository( "snapshots", getTestPath( "target/repo/snapshots" ) ) );
|
||||||
|
configuration.addProxyConnector( createProxyConnector( "internal", REPO_ID) );
|
||||||
|
|
||||||
archivaConfiguration.getConfiguration();
|
archivaConfiguration.getConfiguration();
|
||||||
archivaConfigurationControl.setReturnValue( configuration );
|
archivaConfigurationControl.setReturnValue( configuration, 4 );
|
||||||
archivaConfiguration.getConfiguration();
|
|
||||||
archivaConfigurationControl.setReturnValue( configuration );
|
|
||||||
|
|
||||||
archivaConfiguration.save( configuration );
|
archivaConfiguration.save( configuration );
|
||||||
archivaConfigurationControl.replay();
|
archivaConfigurationControl.replay();
|
||||||
|
@ -106,10 +109,13 @@ public class DeleteRemoteRepositoryActionTest
|
||||||
assertNotNull( repository );
|
assertNotNull( repository );
|
||||||
assertRepositoryEquals( repository, createRepository() );
|
assertRepositoryEquals( repository, createRepository() );
|
||||||
|
|
||||||
|
assertEquals( 1, configuration.getProxyConnectors().size() );
|
||||||
|
|
||||||
String status = action.delete();
|
String status = action.delete();
|
||||||
assertEquals( Action.SUCCESS, status );
|
assertEquals( Action.SUCCESS, status );
|
||||||
|
|
||||||
assertTrue( configuration.getRemoteRepositories().isEmpty() );
|
assertTrue( configuration.getRemoteRepositories().isEmpty() );
|
||||||
|
assertEquals( 0, configuration.getProxyConnectors().size() );
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testDeleteRemoteRepositoryCancelled()
|
public void testDeleteRemoteRepositoryCancelled()
|
||||||
|
@ -119,9 +125,7 @@ public class DeleteRemoteRepositoryActionTest
|
||||||
Configuration configuration = createConfigurationForEditing( originalRepository );
|
Configuration configuration = createConfigurationForEditing( originalRepository );
|
||||||
|
|
||||||
archivaConfiguration.getConfiguration();
|
archivaConfiguration.getConfiguration();
|
||||||
archivaConfigurationControl.setReturnValue( configuration );
|
archivaConfigurationControl.setReturnValue( configuration, 2 );
|
||||||
archivaConfiguration.getConfiguration();
|
|
||||||
archivaConfigurationControl.setReturnValue( configuration );
|
|
||||||
|
|
||||||
archivaConfiguration.save( configuration );
|
archivaConfiguration.save( configuration );
|
||||||
archivaConfigurationControl.replay();
|
archivaConfigurationControl.replay();
|
||||||
|
@ -166,6 +170,32 @@ public class DeleteRemoteRepositoryActionTest
|
||||||
assertEquals( expectedRepository.getName(), actualRepository.getName() );
|
assertEquals( expectedRepository.getName(), actualRepository.getName() );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private ManagedRepositoryConfiguration createManagedRepository( String string, String testPath )
|
||||||
|
{
|
||||||
|
ManagedRepositoryConfiguration r = new ManagedRepositoryConfiguration();
|
||||||
|
r.setId( REPO_ID );
|
||||||
|
r.setName( "repo name" );
|
||||||
|
r.setLocation( testPath );
|
||||||
|
r.setLayout( "default" );
|
||||||
|
r.setRefreshCronExpression( "* 0/5 * * * ?" );
|
||||||
|
r.setDaysOlder( 0 );
|
||||||
|
r.setRetentionCount( 0 );
|
||||||
|
r.setReleases( true );
|
||||||
|
r.setSnapshots( true );
|
||||||
|
r.setScanned( false );
|
||||||
|
r.setDeleteReleasedSnapshots( false );
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
private ProxyConnectorConfiguration createProxyConnector( String managedRepoId, String remoteRepoId )
|
||||||
|
{
|
||||||
|
ProxyConnectorConfiguration connector = new ProxyConnectorConfiguration();
|
||||||
|
connector.setSourceRepoId( managedRepoId );
|
||||||
|
connector.setTargetRepoId( remoteRepoId );
|
||||||
|
|
||||||
|
return connector;
|
||||||
|
}
|
||||||
|
|
||||||
private void populateRepository( RemoteRepositoryConfiguration repository )
|
private void populateRepository( RemoteRepositoryConfiguration repository )
|
||||||
{
|
{
|
||||||
repository.setId( REPO_ID );
|
repository.setId( REPO_ID );
|
||||||
|
@ -174,6 +204,5 @@ public class DeleteRemoteRepositoryActionTest
|
||||||
repository.setLayout( "default" );
|
repository.setLayout( "default" );
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: what if there are proxy connectors attached to a deleted repository?
|
|
||||||
// TODO: what about removing proxied content if a proxy is removed?
|
// TODO: what about removing proxied content if a proxy is removed?
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue