From d72ee0c68bde62907f62a15c70d3230957e53594 Mon Sep 17 00:00:00 2001 From: "Jevica Arianne B. Zurbano" Date: Fri, 29 Apr 2011 11:30:08 +0000 Subject: [PATCH] [MRM-1470] Ability to add a repository relative to Archiva's appserver.base without knowing it's filesystem location * applied patch Submitted by: Maria Catherine Tan git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1097776 13f79535-47bb-0310-9956-ffa450edef68 --- .../AbstractManagedRepositoriesAction.java | 25 +++++++++++- .../AddManagedRepositoryAction.java | 2 + .../EditManagedRepositoryAction.java | 2 + .../webapp/WEB-INF/applicationContext.xml | 1 + .../AddManagedRepositoryActionTest.java | 36 +++++++++++++++-- .../EditManagedRepositoryActionTest.java | 40 ++++++++++++++++--- .../services/AdministrationServiceImpl.java | 18 ++++++++- .../AdministrationServiceImplTest.java | 18 ++++++++- 8 files changed, 128 insertions(+), 14 deletions(-) diff --git a/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/repositories/AbstractManagedRepositoriesAction.java b/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/repositories/AbstractManagedRepositoriesAction.java index 8289add2d..ce821dedd 100644 --- a/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/repositories/AbstractManagedRepositoriesAction.java +++ b/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/repositories/AbstractManagedRepositoriesAction.java @@ -20,11 +20,13 @@ package org.apache.maven.archiva.web.action.admin.repositories; */ import org.apache.commons.io.FileUtils; +import org.apache.commons.lang.StringUtils; import org.apache.maven.archiva.configuration.Configuration; import org.apache.maven.archiva.configuration.ManagedRepositoryConfiguration; import org.apache.maven.archiva.security.ArchivaRoleConstants; import org.codehaus.plexus.redback.role.RoleManager; import org.codehaus.plexus.redback.role.RoleManagerException; +import org.codehaus.plexus.registry.Registry; import java.io.File; import java.io.IOException; @@ -43,7 +45,14 @@ public abstract class AbstractManagedRepositoriesAction * @plexus.requirement role-hint="default" */ protected RoleManager roleManager; - + + /** + * Plexus registry to read the configuration from. + * + * @plexus.requirement role-hint="commons-configuration" + */ + private Registry registry; + public static final String CONFIRM = "confirm"; public RoleManager getRoleManager() @@ -56,6 +65,11 @@ public abstract class AbstractManagedRepositoriesAction this.roleManager = roleManager; } + public void setRegistry( Registry registry ) + { + this.registry = registry; + } + protected void addRepository( ManagedRepositoryConfiguration repository, Configuration configuration ) throws IOException { @@ -129,4 +143,13 @@ public abstract class AbstractManagedRepositoriesAction log.debug( "removed user roles associated with repository " + repoId ); } + + protected String removeExpressions( String directory ) + { + String value = StringUtils.replace( directory, "${appserver.base}", registry.getString( "appserver.base", + "${appserver.base}" ) ); + value = StringUtils.replace( value, "${appserver.home}", registry.getString( "appserver.home", + "${appserver.home}" ) ); + return value; + } } diff --git a/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/repositories/AddManagedRepositoryAction.java b/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/repositories/AddManagedRepositoryAction.java index 922a689bc..9b7f69d86 100644 --- a/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/repositories/AddManagedRepositoryAction.java +++ b/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/repositories/AddManagedRepositoryAction.java @@ -74,6 +74,8 @@ public class AddManagedRepositoryAction public String commit() { + repository.setLocation( removeExpressions( repository.getLocation() ) ); + File location = new File( repository.getLocation() ); if( location.exists() ) { diff --git a/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/repositories/EditManagedRepositoryAction.java b/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/repositories/EditManagedRepositoryAction.java index 4e193c17f..0bdd644d2 100644 --- a/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/repositories/EditManagedRepositoryAction.java +++ b/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/repositories/EditManagedRepositoryAction.java @@ -100,6 +100,8 @@ public class EditManagedRepositoryAction boolean resetStats = false; // check if the location was changed + repository.setLocation( removeExpressions( repository.getLocation() ) ); + if ( !StringUtils.equalsIgnoreCase( existingConfig.getLocation().trim(), repository.getLocation().trim() ) ) { resetStats = true; diff --git a/archiva-modules/archiva-web/archiva-webapp/src/main/webapp/WEB-INF/applicationContext.xml b/archiva-modules/archiva-web/archiva-webapp/src/main/webapp/WEB-INF/applicationContext.xml index 6cf66939e..0accd645a 100644 --- a/archiva-modules/archiva-web/archiva-webapp/src/main/webapp/WEB-INF/applicationContext.xml +++ b/archiva-modules/archiva-web/archiva-webapp/src/main/webapp/WEB-INF/applicationContext.xml @@ -60,6 +60,7 @@ + diff --git a/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/admin/repositories/AddManagedRepositoryActionTest.java b/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/admin/repositories/AddManagedRepositoryActionTest.java index 634ea5a79..34549ba59 100644 --- a/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/admin/repositories/AddManagedRepositoryActionTest.java +++ b/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/admin/repositories/AddManagedRepositoryActionTest.java @@ -30,6 +30,7 @@ import org.apache.maven.archiva.configuration.ManagedRepositoryConfiguration; import org.apache.maven.archiva.security.ArchivaRoleConstants; import org.apache.maven.archiva.web.action.AbstractActionTestCase; import org.codehaus.plexus.redback.role.RoleManager; +import org.codehaus.plexus.registry.Registry; import org.codehaus.plexus.spring.PlexusInSpringTestCase; import org.codehaus.redback.integration.interceptor.SecureActionBundle; import org.codehaus.redback.integration.interceptor.SecureActionException; @@ -51,6 +52,10 @@ public class AddManagedRepositoryActionTest private MockControl archivaConfigurationControl; + private Registry registry; + + private MockControl registryControl; + private ArchivaConfiguration archivaConfiguration; private static final String REPO_ID = "repo-ident"; @@ -72,6 +77,11 @@ public class AddManagedRepositoryActionTest roleManagerControl = MockControl.createControl( RoleManager.class ); roleManager = (RoleManager) roleManagerControl.getMock(); action.setRoleManager( roleManager ); + + registryControl = MockControl.createControl( Registry.class ); + registry = (Registry) registryControl.getMock(); + action.setRegistry( registry ); + location = getTestFile( "target/test/location" ); } @@ -131,6 +141,13 @@ public class AddManagedRepositoryActionTest roleManagerControl.replay(); + registry.getString( "appserver.base", "${appserver.base}" ); + registryControl.setReturnValue( "target/test" ); + registry.getString( "appserver.home", "${appserver.home}" ); + registryControl.setReturnValue( "target/test" ); + + registryControl.replay(); + Configuration configuration = new Configuration(); archivaConfiguration.getConfiguration(); archivaConfigurationControl.setReturnValue( configuration ); @@ -146,11 +163,13 @@ public class AddManagedRepositoryActionTest assertFalse( location.exists() ); String status = action.commit(); assertEquals( Action.SUCCESS, status ); - assertTrue( location.exists() ); + assertTrue( location.exists() ); assertEquals( Collections.singletonList( repository ), configuration.getManagedRepositories() ); + assertEquals( location.getCanonicalPath(), new File( repository.getLocation() ).getCanonicalPath() ); roleManagerControl.verify(); archivaConfigurationControl.verify(); + registryControl.verify(); } @@ -160,8 +179,15 @@ public class AddManagedRepositoryActionTest if( !location.exists() ) { location.mkdirs(); - } - + } + + registry.getString( "appserver.base", "${appserver.base}" ); + registryControl.setReturnValue( "target/test" ); + registry.getString( "appserver.home", "${appserver.home}" ); + registryControl.setReturnValue( "target/test" ); + + registryControl.replay(); + action.prepare(); ManagedRepositoryConfiguration repository = action.getRepository(); populateRepository( repository ); @@ -169,13 +195,15 @@ public class AddManagedRepositoryActionTest assertTrue( location.exists() ); String status = action.commit(); assertEquals( AddManagedRepositoryAction.CONFIRM, status ); + assertEquals( location.getCanonicalPath(), new File( repository.getLocation() ).getCanonicalPath() ); + registryControl.verify(); } private void populateRepository( ManagedRepositoryConfiguration repository ) { repository.setId( REPO_ID ); repository.setName( "repo name" ); - repository.setLocation( location.getAbsolutePath() ); + repository.setLocation( "${appserver.base}/location" ); repository.setLayout( "default" ); repository.setRefreshCronExpression( "* 0/5 * * * ?" ); repository.setDaysOlder( 31 ); diff --git a/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/admin/repositories/EditManagedRepositoryActionTest.java b/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/admin/repositories/EditManagedRepositoryActionTest.java index 8ece1ab0b..aa643ef4b 100644 --- a/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/admin/repositories/EditManagedRepositoryActionTest.java +++ b/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/admin/repositories/EditManagedRepositoryActionTest.java @@ -32,6 +32,7 @@ import org.apache.maven.archiva.configuration.ManagedRepositoryConfiguration; import org.apache.maven.archiva.security.ArchivaRoleConstants; import org.apache.maven.archiva.web.action.AbstractActionTestCase; import org.codehaus.plexus.redback.role.RoleManager; +import org.codehaus.plexus.registry.Registry; import org.codehaus.plexus.spring.PlexusInSpringTestCase; import org.codehaus.redback.integration.interceptor.SecureActionBundle; import org.codehaus.redback.integration.interceptor.SecureActionException; @@ -62,6 +63,10 @@ public class EditManagedRepositoryActionTest private ArchivaConfiguration archivaConfiguration; + private Registry registry; + + private MockControl registryControl; + private static final String REPO_ID = "repo-ident"; private File location; @@ -82,6 +87,11 @@ public class EditManagedRepositoryActionTest roleManagerControl = MockControl.createControl( RoleManager.class ); roleManager = (RoleManager) roleManagerControl.getMock(); action.setRoleManager( roleManager ); + + registryControl = MockControl.createControl( Registry.class ); + registry = (Registry) registryControl.getMock(); + action.setRegistry( registry ); + location = getTestFile( "target/test/location" ); metadataRepository = mock( MetadataRepository.class ); @@ -124,7 +134,10 @@ public class EditManagedRepositoryActionTest assertEquals( REPO_ID, action.getRepoid() ); ManagedRepositoryConfiguration repository = action.getRepository(); assertNotNull( repository ); - assertRepositoryEquals( repository, createRepository() ); + + ManagedRepositoryConfiguration newRepository = createRepository(); + assertRepositoryEquals( repository, newRepository ); + assertEquals( repository.getLocation(), newRepository.getLocation() ); String status = action.input(); assertEquals( Action.INPUT, status ); @@ -154,6 +167,13 @@ public class EditManagedRepositoryActionTest roleManagerControl.replay(); + registry.getString( "appserver.base", "${appserver.base}" ); + registryControl.setReturnValue( "target/test" ); + registry.getString( "appserver.home", "${appserver.home}" ); + registryControl.setReturnValue( "target/test" ); + + registryControl.replay(); + Configuration configuration = createConfigurationForEditing( createRepository() ); archivaConfiguration.getConfiguration(); archivaConfigurationControl.setReturnValue( configuration ); @@ -191,10 +211,12 @@ public class EditManagedRepositoryActionTest newRepository.setName( "new repo name" ); assertRepositoryEquals( repository, newRepository ); assertEquals( Collections.singletonList( repository ), configuration.getManagedRepositories() ); + assertEquals( location.getCanonicalPath(), new File( repository.getLocation() ).getCanonicalPath() ); roleManagerControl.verify(); archivaConfigurationControl.verify(); repositoryStatisticsManagerControl.verify(); + registryControl.verify(); } public void testEditRepositoryLocationChanged() @@ -219,6 +241,13 @@ public class EditManagedRepositoryActionTest roleManagerControl.replay(); + registry.getString( "appserver.base", "${appserver.base}" ); + registryControl.setReturnValue( "target/test" ); + registry.getString( "appserver.home", "${appserver.home}" ); + registryControl.setReturnValue( "target/test" ); + + registryControl.replay(); + Configuration configuration = createConfigurationForEditing( createRepository() ); archivaConfiguration.getConfiguration(); archivaConfigurationControl.setReturnValue( configuration ); @@ -250,15 +279,17 @@ public class EditManagedRepositoryActionTest populateRepository( repository ); File testFile = getTestFile( "target/test/location/new" ); FileUtils.deleteDirectory( testFile ); - repository.setLocation( testFile.getCanonicalPath() ); + repository.setLocation( "${appserver.base}/location/new" ); action.setRepository( repository ); String status = action.commit(); assertEquals( Action.SUCCESS, status ); assertEquals( Collections.singletonList( repository ), configuration.getManagedRepositories() ); + assertEquals( testFile.getCanonicalPath(), new File( repository.getLocation() ).getCanonicalPath() ); roleManagerControl.verify(); archivaConfigurationControl.verify(); repositoryStatisticsManagerControl.verify(); + registryControl.verify(); } private void assertRepositoryEquals( ManagedRepositoryConfiguration expectedRepository, @@ -268,7 +299,6 @@ public class EditManagedRepositoryActionTest assertEquals( expectedRepository.getId(), actualRepository.getId() ); assertEquals( expectedRepository.getIndexDir(), actualRepository.getIndexDir() ); assertEquals( expectedRepository.getLayout(), actualRepository.getLayout() ); - assertEquals( expectedRepository.getLocation(), actualRepository.getLocation() ); assertEquals( expectedRepository.getName(), actualRepository.getName() ); assertEquals( expectedRepository.getRefreshCronExpression(), actualRepository.getRefreshCronExpression() ); assertEquals( expectedRepository.getRetentionCount(), actualRepository.getRetentionCount() ); @@ -310,7 +340,7 @@ public class EditManagedRepositoryActionTest { repository.setId( REPO_ID ); repository.setName( "repo name" ); - repository.setLocation( location.getCanonicalPath() ); + repository.setLocation( "${appserver.base}/location" ); repository.setLayout( "default" ); repository.setRefreshCronExpression( "* 0/5 * * * ?" ); repository.setDaysOlder( 31 ); @@ -326,7 +356,7 @@ public class EditManagedRepositoryActionTest { repository.setId( REPO_ID + "-stage" ); repository.setName( "repo name" ); - repository.setLocation( location.getCanonicalPath() ); + repository.setLocation( "${appserver.base}/location" ); repository.setLayout( "default" ); repository.setRefreshCronExpression( "* 0/5 * * * ?" ); repository.setDaysOlder( 31 ); diff --git a/archiva-modules/archiva-web/archiva-xmlrpc/archiva-xmlrpc-services/src/main/java/org/apache/archiva/web/xmlrpc/services/AdministrationServiceImpl.java b/archiva-modules/archiva-web/archiva-xmlrpc/archiva-xmlrpc-services/src/main/java/org/apache/archiva/web/xmlrpc/services/AdministrationServiceImpl.java index 9f90e0998..6ba6fc174 100644 --- a/archiva-modules/archiva-web/archiva-xmlrpc/archiva-xmlrpc-services/src/main/java/org/apache/archiva/web/xmlrpc/services/AdministrationServiceImpl.java +++ b/archiva-modules/archiva-web/archiva-xmlrpc/archiva-xmlrpc-services/src/main/java/org/apache/archiva/web/xmlrpc/services/AdministrationServiceImpl.java @@ -53,6 +53,7 @@ import org.apache.maven.archiva.repository.ManagedRepositoryContent; import org.apache.maven.archiva.repository.RepositoryContentFactory; import org.apache.maven.archiva.repository.RepositoryException; import org.apache.maven.archiva.repository.RepositoryNotFoundException; +import org.codehaus.plexus.registry.Registry; import org.codehaus.plexus.registry.RegistryException; import org.codehaus.plexus.scheduler.CronExpressionValidator; import org.slf4j.Logger; @@ -96,13 +97,16 @@ public class AdministrationServiceImpl private RepositorySessionFactory repositorySessionFactory; + private Registry registry; + public AdministrationServiceImpl( ArchivaConfiguration archivaConfig, RepositoryContentConsumers repoConsumersUtil, RepositoryContentFactory repoFactory, RepositorySessionFactory repositorySessionFactory, RepositoryArchivaTaskScheduler repositoryTaskScheduler, Collection listeners, RepositoryStatisticsManager repositoryStatisticsManager, - RepositoryMerger repositoryMerger, AuditListener auditListener ) + RepositoryMerger repositoryMerger, AuditListener auditListener, + Registry registry ) { this.archivaConfiguration = archivaConfig; this.repoConsumersUtil = repoConsumersUtil; @@ -113,6 +117,7 @@ public class AdministrationServiceImpl this.repositoryStatisticsManager = repositoryStatisticsManager; this.repositoryMerger = repositoryMerger; this.auditListener = auditListener; + this.registry = registry; } /** @@ -389,7 +394,7 @@ public class AdministrationServiceImpl repository.setReleases( releasesIncluded ); repository.setSnapshots( snapshotsIncluded ); repository.setName( name ); - repository.setLocation( location ); + repository.setLocation( removeExpressions( location ) ); repository.setLayout( layout ); repository.setRefreshCronExpression( cronExpression ); @@ -730,4 +735,13 @@ public class AdministrationServiceImpl stagingRepository.setSnapshots( repository.isSnapshots() ); return stagingRepository; } + + private String removeExpressions( String directory ) + { + String value = StringUtils.replace( directory, "${appserver.base}", registry.getString( "appserver.base", + "${appserver.base}" ) ); + value = StringUtils.replace( value, "${appserver.home}", registry.getString( "appserver.home", + "${appserver.home}" ) ); + return value; + } } diff --git a/archiva-modules/archiva-web/archiva-xmlrpc/archiva-xmlrpc-services/src/test/java/org/apache/archiva/web/xmlrpc/services/AdministrationServiceImplTest.java b/archiva-modules/archiva-web/archiva-xmlrpc/archiva-xmlrpc-services/src/test/java/org/apache/archiva/web/xmlrpc/services/AdministrationServiceImplTest.java index d4eb637ef..c75bb97ba 100644 --- a/archiva-modules/archiva-web/archiva-xmlrpc/archiva-xmlrpc-services/src/test/java/org/apache/archiva/web/xmlrpc/services/AdministrationServiceImplTest.java +++ b/archiva-modules/archiva-web/archiva-xmlrpc/archiva-xmlrpc-services/src/test/java/org/apache/archiva/web/xmlrpc/services/AdministrationServiceImplTest.java @@ -52,6 +52,7 @@ import org.apache.maven.archiva.repository.content.ManagedDefaultRepositoryConte import org.apache.maven.archiva.repository.content.ManagedLegacyRepositoryContent; import org.apache.maven.archiva.repository.content.PathParser; import org.apache.maven.archiva.repository.layout.LayoutException; +import org.codehaus.plexus.registry.Registry; import org.codehaus.plexus.spring.PlexusInSpringTestCase; import org.easymock.MockControl; import org.easymock.classextension.MockClassControl; @@ -132,6 +133,10 @@ public class AdministrationServiceImplTest private AuditListener auditListener; + private MockControl registryControl; + + private Registry registry; + private static final String STAGE = "-stage"; protected void setUp() @@ -185,10 +190,13 @@ public class AdministrationServiceImplTest auditListenerControl = MockControl.createControl( AuditListener.class ); auditListener = (AuditListener) auditListenerControl.getMock(); + registryControl = MockControl.createControl( Registry.class ); + registry = (Registry) registryControl.getMock(); + service = new AdministrationServiceImpl( archivaConfig, repoConsumersUtil, repositoryFactory, repositorySessionFactory, repositoryTaskScheduler, Collections.singletonList( listener ), repositoryStatisticsManager, - repositoryMerger, auditListener ); + repositoryMerger, auditListener, registry ); } /* Tests for repository consumers */ @@ -897,6 +905,7 @@ public class AdministrationServiceImplTest String name = projId + " Releases"; String releaseLocation = "target/test-repository/" + projId + ".releases"; String stageLocation = releaseLocation + "-stage"; + String appserverBase = "target"; ManagedRepositoryConfiguration managedRepo = createManagedRepo( "repo1", "default", "repo", true, false ); RemoteRepositoryConfiguration remoteRepo = createRemoteRepository( "central", "Central Repository", "default", @@ -917,6 +926,8 @@ public class AdministrationServiceImplTest configControl.expectAndReturn( config.getManagedRepositoriesAsMap(), managedRepoMap ); configControl.expectAndReturn( config.getRemoteRepositoriesAsMap(), remoteRepoMap ); configControl.expectAndReturn( config.getRepositoryGroupsAsMap(), repoGroupMap ); + registryControl.expectAndReturn( registry.getString( "appserver.base", "${appserver.base}" ), appserverBase ); + registryControl.expectAndReturn( registry.getString( "appserver.home", "${appserver.home}" ), appserverBase ); config.addManagedRepository( managedRepo ); configControl.setMatcher( MockControl.ALWAYS_MATCHER ); configControl.setVoidCallable(); @@ -928,15 +939,18 @@ public class AdministrationServiceImplTest archivaConfigControl.replay(); configControl.replay(); + registryControl.replay(); assertFalse( new File( releaseLocation ).isDirectory() ); assertFalse( new File( stageLocation ).isDirectory() ); - boolean success = service.addManagedRepository( repoId, layout, name, releaseLocation, true, true, false, true, + boolean success = service.addManagedRepository( repoId, layout, name, "${appserver.base}/test-repository/" + projId + ".releases", true, true, false, true, "0 15 3 * * ? *" ); assertTrue( success ); assertTrue( new File( releaseLocation ).isDirectory() ); assertTrue( new File( stageLocation ).isDirectory() ); new File( releaseLocation ).delete(); new File( stageLocation ).delete(); + + registryControl.verify(); } /* private methods */