mirror of https://github.com/apache/archiva.git
PR: MRM-16
Added missing metadata checks... git-svn-id: https://svn.apache.org/repos/asf/maven/repository-manager/trunk@351563 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
c1678e136b
commit
286bd7bd95
|
@ -18,17 +18,17 @@ package org.apache.maven.repository.reporting;
|
|||
*/
|
||||
|
||||
import java.io.File;
|
||||
import java.util.HashMap;
|
||||
import java.util.Iterator;
|
||||
import org.apache.maven.artifact.Artifact;
|
||||
import org.apache.maven.artifact.factory.ArtifactFactory;
|
||||
import org.apache.maven.artifact.manager.WagonManager;
|
||||
import org.apache.maven.artifact.repository.ArtifactRepository;
|
||||
import org.apache.maven.artifact.repository.metadata.Plugin;
|
||||
import org.apache.maven.artifact.repository.metadata.RepositoryMetadata;
|
||||
import org.apache.maven.artifact.repository.metadata.Snapshot;
|
||||
import org.apache.maven.artifact.repository.metadata.Versioning;
|
||||
import org.apache.maven.repository.RepositoryFileFilter;
|
||||
import org.apache.maven.wagon.ResourceDoesNotExistException;
|
||||
import org.apache.maven.wagon.TransferFailedException;
|
||||
|
||||
|
||||
/**
|
||||
* This class will report on bad metadata files. These include invalid version declarations and incomplete version
|
||||
|
@ -37,8 +37,9 @@ import org.apache.maven.wagon.TransferFailedException;
|
|||
*/
|
||||
public class BadMetadataReporter implements MetadataReportProcessor
|
||||
{
|
||||
private WagonManager wagon;
|
||||
// plexus components
|
||||
private ArtifactFactory artifactFactory;
|
||||
private RepositoryQueryLayer repositoryQueryLayer;
|
||||
|
||||
public void processMetadata( RepositoryMetadata metadata, ArtifactRepository repository, ArtifactReporter reporter )
|
||||
{
|
||||
|
@ -57,7 +58,7 @@ public class BadMetadataReporter implements MetadataReportProcessor
|
|||
}
|
||||
else if ( metadata.storedInArtifactVersionDirectory() )
|
||||
{
|
||||
//snapshot metadata
|
||||
checkSnapshotMetadata( metadata, repository, reporter );
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -77,7 +78,46 @@ public class BadMetadataReporter implements MetadataReportProcessor
|
|||
{
|
||||
boolean hasFailures = false;
|
||||
|
||||
File metadataDir = new File ( repository.getBasedir() + File.pathSeparator + formatAsDirectory( metadata.getGroupId() ) );
|
||||
|
||||
HashMap prefixes = new HashMap();
|
||||
for( Iterator plugins = metadata.getMetadata().getPlugins().iterator(); plugins.hasNext(); )
|
||||
{
|
||||
Plugin plugin = (Plugin) plugins.next();
|
||||
|
||||
String artifactId = plugin.getArtifactId();
|
||||
if ( artifactId == null || artifactId.length() == 0 )
|
||||
{
|
||||
reporter.addFailure( metadata, "Missing or empty artifactId in group metadata." );
|
||||
hasFailures = true;
|
||||
}
|
||||
|
||||
String prefix = plugin.getPrefix();
|
||||
if ( prefix == null || prefix.length() == 0 )
|
||||
{
|
||||
reporter.addFailure( metadata, "Missing or empty plugin prefix for artifactId " + artifactId );
|
||||
hasFailures = true;
|
||||
}
|
||||
else
|
||||
{
|
||||
if ( prefixes.containsKey( prefix ) )
|
||||
{
|
||||
reporter.addFailure( metadata, "Duplicate plugin prefix found: " + prefix );
|
||||
hasFailures = true;
|
||||
}
|
||||
else
|
||||
{
|
||||
prefixes.put( prefix, plugin );
|
||||
}
|
||||
}
|
||||
|
||||
File pluginDir = new File( metadataDir, artifactId );
|
||||
if ( !pluginDir.exists() )
|
||||
{
|
||||
reporter.addFailure( metadata, "Metadata plugin " + artifactId + " is not present in the repository" );
|
||||
hasFailures = true;
|
||||
}
|
||||
}
|
||||
|
||||
return hasFailures;
|
||||
}
|
||||
|
@ -122,21 +162,7 @@ public class BadMetadataReporter implements MetadataReportProcessor
|
|||
|
||||
Artifact artifact = createArtifact( metadata, version );
|
||||
|
||||
try
|
||||
{
|
||||
wagon.getArtifact( artifact, repository );
|
||||
}
|
||||
catch ( TransferFailedException e )
|
||||
{
|
||||
reporter.addWarning( artifact, "An error occurred during the transfer of the artifact in " +
|
||||
"the repository." );
|
||||
}
|
||||
catch ( ResourceDoesNotExistException e )
|
||||
{
|
||||
//do nothing, will check later that this artifact has not been resolved
|
||||
}
|
||||
|
||||
if ( !artifact.isResolved() )
|
||||
if ( !repositoryQueryLayer.containsArtifact( artifact ) )
|
||||
{
|
||||
reporter.addFailure( metadata, "Artifact version " + version + " is present in metadata but " +
|
||||
"missing in the repository." );
|
||||
|
@ -180,12 +206,18 @@ public class BadMetadataReporter implements MetadataReportProcessor
|
|||
return directory.replace( '.', File.pathSeparatorChar );
|
||||
}
|
||||
|
||||
/**
|
||||
* Used to create an artifact object from a metadata base version
|
||||
*/
|
||||
private Artifact createArtifact( RepositoryMetadata metadata )
|
||||
{
|
||||
return artifactFactory.createBuildArtifact( metadata.getGroupId(), metadata.getArtifactId(),
|
||||
metadata.getBaseVersion(), "pom" );
|
||||
}
|
||||
|
||||
/**
|
||||
* Used to create an artifact object with a specified version
|
||||
*/
|
||||
private Artifact createArtifact( RepositoryMetadata metadata, String version )
|
||||
{
|
||||
return artifactFactory.createBuildArtifact( metadata.getGroupId(), metadata.getArtifactId(),
|
||||
|
|
|
@ -18,7 +18,7 @@
|
|||
<implementation>org.apache.maven.repository.reporting.BadMetadataReporter</implementation>
|
||||
<requirements>
|
||||
<requirement>
|
||||
<role>org.apache.maven.artifact.manager.WagonManager</role>
|
||||
<role>org.apache.maven.repository.reporting.RepositoryQueryLayer</role>
|
||||
</requirement>
|
||||
<requirement>
|
||||
<role>org.apache.maven.artifact.factory.ArtifactFactory</role>
|
||||
|
|
Loading…
Reference in New Issue