[MRM-1056] Option to force scanning of an artifact/repository regardless of file dates

o add checkbox for processing all artifacts beside Scan Repository Now button in repositories page
o scan all artifacts if flag is set
o added unit tests


git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@816084 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Maria Odea B. Ching 2009-09-17 07:48:55 +00:00
parent 8604c2f389
commit 40e247c7e4
12 changed files with 179 additions and 29 deletions

View File

@ -585,7 +585,7 @@ public class DefaultRepositoryProxyConnectors
private void queueRepositoryTask( String repositoryId, File localFile ) private void queueRepositoryTask( String repositoryId, File localFile )
{ {
RepositoryTask task = TaskCreator.createRepositoryTask( repositoryId, localFile.getName(), localFile, true ); RepositoryTask task = TaskCreator.createRepositoryTask( repositoryId, localFile.getName(), localFile, true, true );
try try
{ {

View File

@ -428,7 +428,7 @@ public class DefaultArchivaTaskScheduler
private synchronized void queueInitialRepoScan( ManagedRepositoryConfiguration repoConfig ) private synchronized void queueInitialRepoScan( ManagedRepositoryConfiguration repoConfig )
{ {
String repoId = repoConfig.getId(); String repoId = repoConfig.getId();
RepositoryTask task = TaskCreator.createRepositoryTask( repoId, "initial-scan" ); RepositoryTask task = TaskCreator.createRepositoryTask( repoId, "initial-scan", true );
if ( queuedRepos.contains( repoId ) ) if ( queuedRepos.contains( repoId ) )
{ {

View File

@ -59,7 +59,7 @@ public class RepositoryTaskJob
TaskQueue taskQueue = (TaskQueue) dataMap.get( TASK_QUEUE ); TaskQueue taskQueue = (TaskQueue) dataMap.get( TASK_QUEUE );
String queuePolicy = dataMap.get( TASK_QUEUE_POLICY ).toString(); String queuePolicy = dataMap.get( TASK_QUEUE_POLICY ).toString();
RepositoryTask task = TaskCreator.createRepositoryTask( (String) dataMap.get( TASK_REPOSITORY ), "" ); RepositoryTask task = TaskCreator.createRepositoryTask( (String) dataMap.get( TASK_REPOSITORY ), "", true );
task.setName( context.getJobDetail().getName() ); task.setName( context.getJobDetail().getName() );
try try

View File

@ -134,8 +134,11 @@ public class ArchivaRepositoryScanningTaskExecutor
if ( CollectionUtils.isNotEmpty( results ) ) if ( CollectionUtils.isNotEmpty( results ) )
{ {
RepositoryContentStatistics lastStats = results.get( 0 ); RepositoryContentStatistics lastStats = results.get( 0 );
if( !repoTask.isScanAll() )
{
sinceWhen = lastStats.getWhenGathered().getTime() + lastStats.getDuration(); sinceWhen = lastStats.getWhenGathered().getTime() + lastStats.getDuration();
} }
}
RepositoryScanStatistics stats = repoScanner.scan( arepo, sinceWhen ); RepositoryScanStatistics stats = repoScanner.scan( arepo, sinceWhen );

View File

@ -42,6 +42,18 @@ public class RepositoryTask
boolean updateRelatedArtifacts; boolean updateRelatedArtifacts;
boolean scanAll;
public boolean isScanAll()
{
return scanAll;
}
public void setScanAll( boolean scanAll )
{
this.scanAll = scanAll;
}
public String getRepositoryId() public String getRepositoryId()
{ {
return repositoryId; return repositoryId;

View File

@ -31,7 +31,7 @@ import org.apache.maven.archiva.scheduled.DefaultArchivaTaskScheduler;
*/ */
public class TaskCreator public class TaskCreator
{ {
public static RepositoryTask createRepositoryTask( String repositoryId, String taskNameSuffix ) public static RepositoryTask createRepositoryTask( String repositoryId, String taskNameSuffix, boolean scanAll )
{ {
String suffix = ""; String suffix = "";
if( !StringUtils.isEmpty( taskNameSuffix ) ) if( !StringUtils.isEmpty( taskNameSuffix ) )
@ -43,14 +43,15 @@ public class TaskCreator
task.setRepositoryId( repositoryId ); task.setRepositoryId( repositoryId );
task.setName( DefaultArchivaTaskScheduler.REPOSITORY_JOB + ":" + repositoryId + suffix ); task.setName( DefaultArchivaTaskScheduler.REPOSITORY_JOB + ":" + repositoryId + suffix );
task.setQueuePolicy( ArchivaTask.QUEUE_POLICY_WAIT ); task.setQueuePolicy( ArchivaTask.QUEUE_POLICY_WAIT );
task.setScanAll( scanAll );
return task; return task;
} }
public static RepositoryTask createRepositoryTask( String repositoryId, String taskNameSuffix, File resourceFile, public static RepositoryTask createRepositoryTask( String repositoryId, String taskNameSuffix, File resourceFile,
boolean updateRelatedArtifacts ) boolean updateRelatedArtifacts, boolean scanAll )
{ {
RepositoryTask task = createRepositoryTask( repositoryId, taskNameSuffix ); RepositoryTask task = createRepositoryTask( repositoryId, taskNameSuffix, scanAll );
task.setResourceFile( resourceFile ); task.setResourceFile( resourceFile );
task.setUpdateRelatedArtifacts( updateRelatedArtifacts ); task.setUpdateRelatedArtifacts( updateRelatedArtifacts );

View File

@ -21,6 +21,7 @@ package org.apache.maven.archiva.scheduled.executors;
import java.io.File; import java.io.File;
import java.net.URL; import java.net.URL;
import java.util.Calendar;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Properties; import java.util.Properties;
@ -34,11 +35,13 @@ import org.apache.maven.archiva.database.ArchivaDAO;
import org.apache.maven.archiva.database.ArtifactDAO; import org.apache.maven.archiva.database.ArtifactDAO;
import org.apache.maven.archiva.database.constraints.ArtifactsProcessedConstraint; import org.apache.maven.archiva.database.constraints.ArtifactsProcessedConstraint;
import org.apache.maven.archiva.model.ArchivaArtifact; import org.apache.maven.archiva.model.ArchivaArtifact;
import org.apache.maven.archiva.model.RepositoryContentStatistics;
import org.apache.maven.archiva.scheduled.tasks.RepositoryTask; import org.apache.maven.archiva.scheduled.tasks.RepositoryTask;
import org.codehaus.plexus.jdo.DefaultConfigurableJdoFactory; import org.codehaus.plexus.jdo.DefaultConfigurableJdoFactory;
import org.codehaus.plexus.jdo.JdoFactory; import org.codehaus.plexus.jdo.JdoFactory;
import org.codehaus.plexus.spring.PlexusInSpringTestCase; import org.codehaus.plexus.spring.PlexusInSpringTestCase;
import org.codehaus.plexus.taskqueue.execution.TaskExecutor; import org.codehaus.plexus.taskqueue.execution.TaskExecutor;
import org.codehaus.plexus.util.FileUtils;
import org.jpox.SchemaTool; import org.jpox.SchemaTool;
/** /**
@ -53,6 +56,8 @@ public class ArchivaRepositoryScanningTaskExecutorTest
protected ArchivaDAO dao; protected ArchivaDAO dao;
private File repoDir;
protected void setUp() protected void setUp()
throws Exception throws Exception
{ {
@ -131,12 +136,28 @@ public class ArchivaRepositoryScanningTaskExecutorTest
this.dao = (ArchivaDAO) lookup( ArchivaDAO.class.getName(), "jdo" ); this.dao = (ArchivaDAO) lookup( ArchivaDAO.class.getName(), "jdo" );
taskExecutor = (TaskExecutor) lookup( TaskExecutor.class, "test-repository-scanning" ); taskExecutor = (TaskExecutor) lookup( TaskExecutor.class, "test-repository-scanning" );
File sourceRepoDir = new File( getBasedir(), "src/test/repositories/default-repository" );
repoDir = new File( getBasedir(), "target/default-repository" );
repoDir.mkdir();
FileUtils.copyDirectoryStructure( sourceRepoDir, repoDir );
assertTrue( repoDir.exists() );
}
protected void tearDown() throws Exception
{
FileUtils.deleteDirectory( repoDir );
assertFalse( repoDir.exists() );
super.tearDown();
} }
public void testExecutor() throws Exception public void testExecutor() throws Exception
{ {
File repoDir = new File( getBasedir(), "src/test/repositories/default-repository" );
assertTrue( "Default Test Repository should exist.", repoDir.exists() && repoDir.isDirectory() ); assertTrue( "Default Test Repository should exist.", repoDir.exists() && repoDir.isDirectory() );
ArchivaConfiguration archivaConfig = (ArchivaConfiguration) lookup( ArchivaConfiguration.class ); ArchivaConfiguration archivaConfig = (ArchivaConfiguration) lookup( ArchivaConfiguration.class );
@ -162,6 +183,106 @@ public class ArchivaRepositoryScanningTaskExecutorTest
assertEquals("Incorrect number of unprocessed artifacts detected.", 8, unprocessedResultList.size() ); assertEquals("Incorrect number of unprocessed artifacts detected.", 8, unprocessedResultList.size() );
} }
public void testExecutorScanOnlyNewArtifacts()
throws Exception
{
assertTrue( "Default Test Repository should exist.", repoDir.exists() && repoDir.isDirectory() );
ArchivaConfiguration archivaConfig = (ArchivaConfiguration) lookup( ArchivaConfiguration.class );
assertNotNull( archivaConfig );
// Create it
ManagedRepositoryConfiguration repo = createRepository( "testRepo", "Test Repository", repoDir );
assertNotNull( repo );
archivaConfig.getConfiguration().getManagedRepositories().clear();
archivaConfig.getConfiguration().addManagedRepository( repo );
RepositoryTask repoTask = new RepositoryTask();
repoTask.setName( "testRepoTask" );
repoTask.setRepositoryId( "testRepo" );
repoTask.setScanAll( false );
RepositoryContentStatistics stats = new RepositoryContentStatistics();
stats.setDuration( 1234567 );
stats.setNewFileCount( 8 );
stats.setRepositoryId( "testRepo" );
stats.setTotalArtifactCount( 8 );
stats.setTotalFileCount( 8 );
stats.setTotalGroupCount( 3 );
stats.setTotalProjectCount( 5 );
stats.setTotalSize( 999999 );
stats.setWhenGathered( Calendar.getInstance().getTime() );
dao.getRepositoryContentStatisticsDAO().saveRepositoryContentStatistics( stats );
taskExecutor.executeTask( repoTask );
ArtifactDAO adao = dao.getArtifactDAO();
List<ArchivaArtifact> unprocessedResultList = adao.queryArtifacts( new ArtifactsProcessedConstraint( false ) );
assertNotNull( unprocessedResultList );
assertEquals("Incorrect number of unprocessed artifacts detected. No new artifacts should have been found.", 0, unprocessedResultList.size() );
File newArtifactGroup = new File( repoDir, "org/apache/archiva");
FileUtils.copyDirectoryStructure( new File( getBasedir(), "target/test-classes/test-repo/org/apache/archiva"), newArtifactGroup );
// update last modified date
new File( newArtifactGroup, "archiva-index-methods-jar-test/1.0/pom.xml" ).setLastModified( Calendar.getInstance().getTimeInMillis() + 1000 );
new File( newArtifactGroup, "archiva-index-methods-jar-test/1.0/archiva-index-methods-jar-test-1.0.jar" ).setLastModified( Calendar.getInstance().getTimeInMillis() + 1000 );
assertTrue( newArtifactGroup.exists() );
taskExecutor.executeTask( repoTask );
unprocessedResultList = adao.queryArtifacts( new ArtifactsProcessedConstraint( false ) );
assertNotNull( unprocessedResultList );
assertEquals( "Incorrect number of unprocessed artifacts detected. One new artifact should have been found.", 1, unprocessedResultList.size() );
}
public void testExecutorForceScanAll()
throws Exception
{
assertTrue( "Default Test Repository should exist.", repoDir.exists() && repoDir.isDirectory() );
ArchivaConfiguration archivaConfig = (ArchivaConfiguration) lookup( ArchivaConfiguration.class );
assertNotNull( archivaConfig );
// Create it
ManagedRepositoryConfiguration repo = createRepository( "testRepo", "Test Repository", repoDir );
assertNotNull( repo );
archivaConfig.getConfiguration().getManagedRepositories().clear();
archivaConfig.getConfiguration().addManagedRepository( repo );
RepositoryTask repoTask = new RepositoryTask();
repoTask.setName( "testRepoTask" );
repoTask.setRepositoryId( "testRepo" );
repoTask.setScanAll( true );
RepositoryContentStatistics stats = new RepositoryContentStatistics();
stats.setDuration( 1234567 );
stats.setNewFileCount( 8 );
stats.setRepositoryId( "testRepo" );
stats.setTotalArtifactCount( 8 );
stats.setTotalFileCount( 8 );
stats.setTotalGroupCount( 3 );
stats.setTotalProjectCount( 5 );
stats.setTotalSize( 999999 );
stats.setWhenGathered( Calendar.getInstance().getTime() );
dao.getRepositoryContentStatisticsDAO().saveRepositoryContentStatistics( stats );
taskExecutor.executeTask( repoTask );
ArtifactDAO adao = dao.getArtifactDAO();
List<ArchivaArtifact> unprocessedResultList = adao.queryArtifacts( new ArtifactsProcessedConstraint( false ) );
assertNotNull( unprocessedResultList );
assertEquals("Incorrect number of unprocessed artifacts detected.", 8, unprocessedResultList.size() );
}
protected ManagedRepositoryConfiguration createRepository( String id, String name, File location ) protected ManagedRepositoryConfiguration createRepository( String id, String name, File location )
{ {
ManagedRepositoryConfiguration repo = new ManagedRepositoryConfiguration(); ManagedRepositoryConfiguration repo = new ManagedRepositoryConfiguration();

View File

@ -617,7 +617,7 @@ public class UploadAction
private void queueRepositoryTask( String repositoryId, File localFile ) private void queueRepositoryTask( String repositoryId, File localFile )
{ {
RepositoryTask task = TaskCreator.createRepositoryTask( repositoryId, localFile.getName(), localFile, true ); RepositoryTask task = TaskCreator.createRepositoryTask( repositoryId, localFile.getName(), localFile, true, true );
try try
{ {

View File

@ -51,6 +51,8 @@ public class SchedulerAction
private String repoid; private String repoid;
private boolean scanAll;
public String scanRepository() public String scanRepository()
{ {
if ( StringUtils.isBlank( repoid ) ) if ( StringUtils.isBlank( repoid ) )
@ -59,7 +61,7 @@ public class SchedulerAction
return SUCCESS; return SUCCESS;
} }
RepositoryTask task = TaskCreator.createRepositoryTask( repoid, "" ); RepositoryTask task = TaskCreator.createRepositoryTask( repoid, "", scanAll );
boolean scheduleTask = false; boolean scheduleTask = false;
@ -181,4 +183,14 @@ public class SchedulerAction
{ {
this.repoid = repoid; this.repoid = repoid;
} }
public boolean getScanAll()
{
return scanAll;
}
public void setScanAll( boolean scanAll )
{
this.scanAll = scanAll;
}
} }

View File

@ -197,19 +197,20 @@
<th> <th>
Actions Actions
</th> </th>
<td>
<table>
<tr>
<td> <td>
<redback:ifAuthorized permission="archiva-run-indexer"> <redback:ifAuthorized permission="archiva-run-indexer">
<s:form action="indexRepository" theme="simple"> <s:form action="indexRepository" theme="simple">
<s:hidden name="repoid" value="%{#attr.repository.id}"/> <s:hidden name="repoid" value="%{#attr.repository.id}"/>
<s:submit value="Scan Repository Now"/> <table>
</s:form> <tr>
</redback:ifAuthorized> <td><s:checkbox name="scanAll" value="scanAll"/>Process All Artifacts</td>
</td> </tr>
<tr>
<td><s:submit value="Scan Repository Now"/></td>
</tr> </tr>
</table> </table>
</s:form>
</redback:ifAuthorized>
</td> </td>
</tr> </tr>
<tr> <tr>

View File

@ -645,7 +645,7 @@ public class ArchivaDavResource
private void queueRepositoryTask( File localFile ) private void queueRepositoryTask( File localFile )
{ {
RepositoryTask task = TaskCreator.createRepositoryTask( repository.getId(), localFile.getName(), localFile, false ); RepositoryTask task = TaskCreator.createRepositoryTask( repository.getId(), localFile.getName(), localFile, false, true );
try try
{ {

View File

@ -313,7 +313,7 @@ public class AdministrationServiceImpl
} }
} }
RepositoryTask task = TaskCreator.createRepositoryTask( repoId, "" ); RepositoryTask task = TaskCreator.createRepositoryTask( repoId, "", false );
taskScheduler.queueRepositoryTask( task ); taskScheduler.queueRepositoryTask( task );