From e50371591df708ced25391eec1ae1d0f27cf39aa Mon Sep 17 00:00:00 2001
From: Brett Porter
Date: Fri, 28 Sep 2007 03:17:11 +0000
Subject: [PATCH] [MRM-528] run the correct consumers
git-svn-id: https://svn.apache.org/repos/asf/maven/archiva/trunk@580205 13f79535-47bb-0310-9956-ffa450edef68
---
.../consumers/RepositoryContentConsumer.java | 2 +
.../scanner/RepositoryContentConsumers.java | 54 +++++++++--------
.../functors/ConsumerWantsFilePredicate.java | 15 ++---
.../RepositoryContentConsumerUtilTest.java | 59 +++++++++++++++++--
4 files changed, 93 insertions(+), 37 deletions(-)
diff --git a/archiva-base/archiva-consumers/archiva-consumer-api/src/main/java/org/apache/maven/archiva/consumers/RepositoryContentConsumer.java b/archiva-base/archiva-consumers/archiva-consumer-api/src/main/java/org/apache/maven/archiva/consumers/RepositoryContentConsumer.java
index beb778ff2..005423f23 100644
--- a/archiva-base/archiva-consumers/archiva-consumer-api/src/main/java/org/apache/maven/archiva/consumers/RepositoryContentConsumer.java
+++ b/archiva-base/archiva-consumers/archiva-consumer-api/src/main/java/org/apache/maven/archiva/consumers/RepositoryContentConsumer.java
@@ -85,6 +85,8 @@ public interface RepositoryContentConsumer extends BaseConsumer
* NOTE: If the consumer opted to batch up processing requests in the {@link #processFile(String)} event
* this would be the last opportunity to drain any processing queue's.
*
+ *
+ * @todo! this is never called by the RepositoryScannerInstance
*/
public void completeScan();
}
diff --git a/archiva-base/archiva-repository-layer/src/main/java/org/apache/maven/archiva/repository/scanner/RepositoryContentConsumers.java b/archiva-base/archiva-repository-layer/src/main/java/org/apache/maven/archiva/repository/scanner/RepositoryContentConsumers.java
index 6876a7294..a253a2c05 100644
--- a/archiva-base/archiva-repository-layer/src/main/java/org/apache/maven/archiva/repository/scanner/RepositoryContentConsumers.java
+++ b/archiva-base/archiva-repository-layer/src/main/java/org/apache/maven/archiva/repository/scanner/RepositoryContentConsumers.java
@@ -24,15 +24,17 @@ import org.apache.commons.collections.CollectionUtils;
import org.apache.commons.collections.Predicate;
import org.apache.commons.collections.functors.IfClosure;
import org.apache.commons.collections.functors.OrPredicate;
-import org.apache.maven.archiva.common.utils.PathUtil;
+import org.apache.maven.archiva.common.utils.BaseFile;
import org.apache.maven.archiva.configuration.ArchivaConfiguration;
import org.apache.maven.archiva.configuration.RepositoryScanningConfiguration;
-import org.apache.maven.archiva.consumers.ConsumerException;
import org.apache.maven.archiva.consumers.InvalidRepositoryContentConsumer;
import org.apache.maven.archiva.consumers.KnownRepositoryContentConsumer;
import org.apache.maven.archiva.consumers.RepositoryContentConsumer;
import org.apache.maven.archiva.consumers.functors.PermanentConsumerPredicate;
import org.apache.maven.archiva.model.ArchivaRepository;
+import org.apache.maven.archiva.repository.scanner.functors.ConsumerProcessFileClosure;
+import org.apache.maven.archiva.repository.scanner.functors.ConsumerWantsFilePredicate;
+import org.apache.maven.archiva.repository.scanner.functors.TriggerBeginScanClosure;
import org.codehaus.plexus.logging.AbstractLogEnabled;
import org.codehaus.plexus.personality.plexus.lifecycle.phase.Initializable;
import org.codehaus.plexus.personality.plexus.lifecycle.phase.InitializationException;
@@ -213,32 +215,38 @@ public class RepositoryContentConsumers
public void executeConsumers( ArchivaRepository repository, File localFile )
{
// Run the repository consumers
- for ( RepositoryContentConsumer consumer : availableKnownConsumers )
- {
- consumeFile( consumer, repository, localFile );
- }
-
- for ( RepositoryContentConsumer consumer : availableInvalidConsumers )
- {
- consumeFile( consumer, repository, localFile );
- }
- }
-
- private void consumeFile( RepositoryContentConsumer consumer, ArchivaRepository repository, File localFile )
- {
try
{
- consumer.beginScan( repository );
- consumer.processFile( PathUtil.getRelative( repository.getUrl().getPath(), localFile ) );
- }
- catch ( ConsumerException e )
- {
- getLogger().error( "Error processing file: " + localFile, e );
- // ignore, let next repo scan handle it
+ Closure triggerBeginScan = new TriggerBeginScanClosure( repository, getLogger() );
+
+ CollectionUtils.forAllDo( availableKnownConsumers, triggerBeginScan );
+ CollectionUtils.forAllDo( availableInvalidConsumers, triggerBeginScan );
+
+ // yuck. In case you can't read this, it says
+ // "process the file if the consumer has it in the includes list, and not in the excludes list"
+ BaseFile baseFile = new BaseFile( repository.getUrl().getPath(), localFile );
+ ConsumerWantsFilePredicate predicate = new ConsumerWantsFilePredicate();
+ predicate.setBasefile( baseFile );
+ ConsumerProcessFileClosure closure = new ConsumerProcessFileClosure( getLogger() );
+ closure.setBasefile( baseFile );
+ predicate.setCaseSensitive( false );
+ Closure processIfWanted = IfClosure.getInstance( predicate, closure );
+
+ CollectionUtils.forAllDo( availableKnownConsumers, processIfWanted );
+
+ if ( predicate.getWantedFileCount() <= 0 )
+ {
+ // Nothing known processed this file. It is invalid!
+ CollectionUtils.forAllDo( availableInvalidConsumers, closure );
+ }
}
finally
{
- consumer.completeScan();
+/* TODO: This is never called by the repository scanner instance, so not calling here either - but it probably should be?
+ CollectionUtils.forAllDo( availableKnownConsumers, triggerCompleteScan );
+ CollectionUtils.forAllDo( availableInvalidConsumers, triggerCompleteScan );
+*/
}
}
+
}
diff --git a/archiva-base/archiva-repository-layer/src/main/java/org/apache/maven/archiva/repository/scanner/functors/ConsumerWantsFilePredicate.java b/archiva-base/archiva-repository-layer/src/main/java/org/apache/maven/archiva/repository/scanner/functors/ConsumerWantsFilePredicate.java
index 799985165..2d154294c 100644
--- a/archiva-base/archiva-repository-layer/src/main/java/org/apache/maven/archiva/repository/scanner/functors/ConsumerWantsFilePredicate.java
+++ b/archiva-base/archiva-repository-layer/src/main/java/org/apache/maven/archiva/repository/scanner/functors/ConsumerWantsFilePredicate.java
@@ -25,7 +25,7 @@ import org.apache.maven.archiva.consumers.RepositoryContentConsumer;
import org.codehaus.plexus.util.SelectorUtils;
import org.codehaus.plexus.util.StringUtils;
-import java.util.Iterator;
+import java.util.List;
/**
* ConsumerWantsFilePredicate
@@ -87,15 +87,12 @@ public class ConsumerWantsFilePredicate
private boolean wantsFile( RepositoryContentConsumer consumer, String relativePath )
{
- Iterator it;
-
// Test excludes first.
- if ( consumer.getExcludes() != null )
+ List excludes = consumer.getExcludes();
+ if ( excludes != null )
{
- it = consumer.getExcludes().iterator();
- while ( it.hasNext() )
+ for ( String pattern : excludes )
{
- String pattern = (String) it.next();
if ( SelectorUtils.matchPath( pattern, relativePath, isCaseSensitive ) )
{
// Definately does NOT WANT FILE.
@@ -105,10 +102,8 @@ public class ConsumerWantsFilePredicate
}
// Now test includes.
- it = consumer.getIncludes().iterator();
- while ( it.hasNext() )
+ for ( String pattern : consumer.getIncludes() )
{
- String pattern = (String) it.next();
if ( SelectorUtils.matchPath( pattern, relativePath, isCaseSensitive ) )
{
// Specifically WANTS FILE.
diff --git a/archiva-base/archiva-repository-layer/src/test/java/org/apache/maven/archiva/repository/scanner/RepositoryContentConsumerUtilTest.java b/archiva-base/archiva-repository-layer/src/test/java/org/apache/maven/archiva/repository/scanner/RepositoryContentConsumerUtilTest.java
index 2f2a751bb..707cac441 100644
--- a/archiva-base/archiva-repository-layer/src/test/java/org/apache/maven/archiva/repository/scanner/RepositoryContentConsumerUtilTest.java
+++ b/archiva-base/archiva-repository-layer/src/test/java/org/apache/maven/archiva/repository/scanner/RepositoryContentConsumerUtilTest.java
@@ -109,7 +109,7 @@ public class RepositoryContentConsumerUtilTest
public void testExecution()
throws Exception
{
- MockControl knownControl = MockControl.createControl( KnownRepositoryContentConsumer.class );
+ MockControl knownControl = MockControl.createNiceControl( KnownRepositoryContentConsumer.class );
RepositoryContentConsumers consumers = lookupRepositoryConsumerUtil();
KnownRepositoryContentConsumer knownConsumer = (KnownRepositoryContentConsumer) knownControl.getMock();
consumers.setAvailableKnownConsumers( Collections.singletonList( knownConsumer ) );
@@ -123,18 +123,69 @@ public class RepositoryContentConsumerUtilTest
File testFile = getTestFile( "target/test-repo/path/to/test-file.txt" );
knownConsumer.beginScan( repo );
+ knownConsumer.getExcludes();
+ knownControl.setReturnValue( Collections.EMPTY_LIST );
+ knownConsumer.getIncludes();
+ knownControl.setReturnValue( Collections.singletonList( "**/*.txt" ) );
knownConsumer.processFile( "path/to/test-file.txt" );
- knownConsumer.completeScan();
+// knownConsumer.completeScan();
knownControl.replay();
invalidConsumer.beginScan( repo );
- invalidConsumer.processFile( "path/to/test-file.txt" );
- invalidConsumer.completeScan();
+// invalidConsumer.completeScan();
invalidControl.replay();
consumers.executeConsumers( repo, testFile );
knownControl.verify();
invalidControl.verify();
+
+ knownControl.reset();
+ invalidControl.reset();
+
+ File notIncludedTestFile = getTestFile( "target/test-repo/path/to/test-file.xml" );
+
+ knownConsumer.beginScan( repo );
+ knownConsumer.getExcludes();
+ knownControl.setReturnValue( Collections.EMPTY_LIST );
+ knownConsumer.getIncludes();
+ knownControl.setReturnValue( Collections.singletonList( "**/*.txt" ) );
+// knownConsumer.completeScan();
+ knownControl.replay();
+
+ invalidConsumer.beginScan( repo );
+ invalidConsumer.processFile( "path/to/test-file.xml" );
+ invalidConsumer.getId();
+ invalidControl.setReturnValue( "invalid" );
+// invalidConsumer.completeScan();
+ invalidControl.replay();
+
+ consumers.executeConsumers( repo, notIncludedTestFile );
+
+ knownControl.verify();
+ invalidControl.verify();
+
+ knownControl.reset();
+ invalidControl.reset();
+
+ File excludedTestFile = getTestFile( "target/test-repo/path/to/test-file.txt" );
+
+ knownConsumer.beginScan( repo );
+ knownConsumer.getExcludes();
+ knownControl.setReturnValue( Collections.singletonList( "**/test-file.txt" ) );
+// knownConsumer.completeScan();
+ knownControl.replay();
+
+ invalidConsumer.beginScan( repo );
+ invalidConsumer.processFile( "path/to/test-file.txt" );
+ invalidConsumer.getId();
+ invalidControl.setReturnValue( "invalid" );
+// invalidConsumer.completeScan();
+ invalidControl.replay();
+
+ consumers.executeConsumers( repo, excludedTestFile );
+
+ knownControl.verify();
+ invalidControl.verify();
}
}