private boolean executeOnEntireRepo = true;
+ /**
+ * @since 1.4
+ */
+ private boolean onlyUpdate = false;
+
public ArtifactIndexingTask( ManagedRepositoryConfiguration repository, File resourceFile, Action action,
IndexingContext context )
{
this.executeOnEntireRepo = executeOnEntireRepo;
}
+ public ArtifactIndexingTask( ManagedRepositoryConfiguration repository, File resourceFile, Action action,
+ IndexingContext context, boolean executeOnEntireRepo, boolean onlyUpdate )
+ {
+ this( repository, resourceFile, action, context, executeOnEntireRepo );
+ this.onlyUpdate = onlyUpdate;
+ }
+
public boolean isExecuteOnEntireRepo()
{
return executeOnEntireRepo;
return action;
}
- @Override
- public String toString()
- {
- return "ArtifactIndexingTask [action=" + action + ", repositoryId=" + repository.getId() + ", resourceFile="
- + resourceFile + "]";
- }
-
public ManagedRepositoryConfiguration getRepository()
{
return repository;
return context;
}
+ public boolean isOnlyUpdate()
+ {
+ return onlyUpdate;
+ }
+
+ public void setOnlyUpdate( boolean onlyUpdate )
+ {
+ this.onlyUpdate = onlyUpdate;
+ }
+
@Override
public int hashCode()
{
return true;
}
+
+ @Override
+ public String toString()
+ {
+ return "ArtifactIndexingTask [action=" + action + ", repositoryId=" + repository.getId() + ", resourceFile="
+ + resourceFile + "]";
+ }
+
+ /**
+ * FIXME remove this static somewhere else !
+ * @param repository
+ * @param indexer
+ * @param indexCreators
+ * @return
+ * @throws IOException
+ * @throws UnsupportedExistingLuceneIndexException
+ */
public static IndexingContext createContext( ManagedRepositoryConfiguration repository, NexusIndexer indexer,
List<? extends IndexCreator> indexCreators )
throws IOException, UnsupportedExistingLuceneIndexException
ArtifactIndexingTask task =
new ArtifactIndexingTask( repositoryConfig, artifactFile, ArtifactIndexingTask.Action.ADD,
getIndexingContext() );
+ task.setExecuteOnEntireRepo( false );
indexingExecutor.executeTask( task );
task = new ArtifactIndexingTask( repositoryConfig, artifactFile, ArtifactIndexingTask.Action.FINISH,
getIndexingContext() );
+ task.setExecuteOnEntireRepo( false );
+
indexingExecutor.executeTask( task );
assertTrue( new File( repositoryConfig.getLocation(), ".indexer" ).exists() );
FlatSearchRequest request = new FlatSearchRequest( q, getIndexingContext() );
FlatSearchResponse response = indexer.searchFlat( request );
- assertEquals( 1, response.getTotalHits() );
-
Set<ArtifactInfo> results = response.getResults();
- ArtifactInfo artifactInfo = (ArtifactInfo) results.iterator().next();
+ ArtifactInfo artifactInfo = results.iterator().next();
assertEquals( "org.apache.archiva", artifactInfo.groupId );
assertEquals( "archiva-index-methods-jar-test", artifactInfo.artifactId );
assertEquals( "test-repo", artifactInfo.repository );
+
+ assertEquals( 1, response.getTotalHits() );
}
private void unzipIndex( String indexDir, String destDir )