[MRM-262] Reporting adds duplicated entries on each run

git-svn-id: https://svn.apache.org/repos/asf/maven/archiva/trunk@489678 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Carlos Sanchez Gonzalez 2006-12-22 15:56:26 +00:00
parent 8aa9aaf41b
commit fa19720b7f
3 changed files with 219 additions and 14 deletions

View File

@ -92,8 +92,12 @@ public class ReportingDatabase
public void addFailure( Artifact artifact, String processor, String problem, String reason )
{
ArtifactResults results = getArtifactResults( artifact );
results.addFailure( createResult( processor, problem, reason ) );
Result result = createResult( processor, problem, reason );
if ( !results.getFailures().contains( result ) )
{
results.addFailure( result );
numFailures++;
}
updateTimings();
if ( filteredDatabases.containsKey( problem ) )
@ -107,8 +111,12 @@ public class ReportingDatabase
public void addNotice( Artifact artifact, String processor, String problem, String reason )
{
ArtifactResults results = getArtifactResults( artifact );
results.addNotice( createResult( processor, problem, reason ) );
Result result = createResult( processor, problem, reason );
if ( !results.getNotices().contains( result ) )
{
results.addNotice( result );
numNotices++;
}
updateTimings();
if ( filteredDatabases.containsKey( problem ) )
@ -122,8 +130,12 @@ public class ReportingDatabase
public void addWarning( Artifact artifact, String processor, String problem, String reason )
{
ArtifactResults results = getArtifactResults( artifact );
results.addWarning( createResult( processor, problem, reason ) );
Result result = createResult( processor, problem, reason );
if ( !results.getWarnings().contains( result ) )
{
results.addWarning( result );
numWarnings++;
}
updateTimings();
if ( filteredDatabases.containsKey( problem ) )
@ -134,7 +146,7 @@ public class ReportingDatabase
}
}
private ArtifactResults getArtifactResults( Artifact artifact )
ArtifactResults getArtifactResults( Artifact artifact )
{
return getArtifactResults( artifact.getGroupId(), artifact.getArtifactId(), artifact.getVersion(),
artifact.getType(), artifact.getClassifier() );
@ -203,8 +215,12 @@ public class ReportingDatabase
{
metadataWithProblems.add( results );
}
results.addFailure( createResult( processor, problem, reason ) );
Result result = createResult( processor, problem, reason );
if ( !results.getFailures().contains( result ) )
{
results.addFailure( result );
numFailures++;
}
updateTimings();
if ( filteredDatabases.containsKey( problem ) )
@ -222,8 +238,12 @@ public class ReportingDatabase
{
metadataWithProblems.add( results );
}
results.addWarning( createResult( processor, problem, reason ) );
Result result = createResult( processor, problem, reason );
if ( !results.getWarnings().contains( result ) )
{
results.addWarning( result );
numWarnings++;
}
updateTimings();
if ( filteredDatabases.containsKey( problem ) )
@ -241,8 +261,12 @@ public class ReportingDatabase
{
metadataWithProblems.add( results );
}
results.addNotice( createResult( processor, problem, reason ) );
Result result = createResult( processor, problem, reason );
if ( !results.getNotices().contains( result ) )
{
results.addNotice( result );
numNotices++;
}
updateTimings();
if ( filteredDatabases.containsKey( problem ) )
@ -346,7 +370,7 @@ public class ReportingDatabase
metadataWithProblems.remove( results );
}
private MetadataResults getMetadataResults( RepositoryMetadata metadata, long lastModified )
MetadataResults getMetadataResults( RepositoryMetadata metadata, long lastModified )
{
return getMetadataResults( metadata.getGroupId(), metadata.getArtifactId(), metadata.getBaseVersion(),
lastModified );

View File

@ -238,6 +238,41 @@
</description>
</field>
</fields>
<codeSegments>
<codeSegment>
<version>1.0.0</version>
<code><![CDATA[
public boolean equals( Object obj )
{
if ( obj instanceof Result )
{
if ( this == obj )
{
return true;
}
Result rhs = (Result) obj;
return new org.apache.commons.lang.builder.EqualsBuilder()
.append( problem, rhs.problem )
.append( processor, rhs.processor )
.append( reason, rhs.reason )
.isEquals();
}
return false;
}
public int hashCode()
{
return new org.apache.commons.lang.builder.HashCodeBuilder( 19, 43 )
.append( getReason() )
.append( getProcessor() )
.append( getProblem() )
.toHashCode();
}
]]></code>
</codeSegment>
</codeSegments>
</class>
</classes>
</model>

View File

@ -0,0 +1,146 @@
package org.apache.maven.archiva.reporting.database;
/*
* Copyright 2006 The Apache Software Foundation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import junit.framework.TestCase;
import org.apache.maven.archiva.reporting.model.ArtifactResults;
import org.apache.maven.archiva.reporting.model.MetadataResults;
import org.apache.maven.artifact.Artifact;
import org.apache.maven.artifact.DefaultArtifact;
import org.apache.maven.artifact.repository.metadata.ArtifactRepositoryMetadata;
import org.apache.maven.artifact.repository.metadata.RepositoryMetadata;
import org.apache.maven.artifact.versioning.VersionRange;
/**
* Test for {@link ReportingDatabase}.
*
* @author <a href="mailto:carlos@apache.org">Carlos Sanchez</a>
* @version $Id$
*/
public class ReportingDatabaseTest
extends TestCase
{
private Artifact artifact;
private String processor, problem, reason;
private ReportingDatabase reportingDatabase;
private RepositoryMetadata metadata;
protected void setUp()
throws Exception
{
super.setUp();
artifact = new DefaultArtifact( "group", "artifact", VersionRange.createFromVersion( "1.0" ), "scope", "type",
"classifier", null );
processor = "processor";
problem = "problem";
reason = "reason";
reportingDatabase = new ReportingDatabase( null );
metadata = new ArtifactRepositoryMetadata( artifact );
}
public void testAddNoticeArtifactStringStringString()
{
reportingDatabase.addNotice( artifact, processor, problem, reason );
ArtifactResults artifactResults = reportingDatabase.getArtifactResults( artifact );
assertEquals( 1, reportingDatabase.getNumNotices() );
assertEquals( 1, artifactResults.getNotices().size() );
reportingDatabase.addNotice( artifact, processor, problem, reason );
artifactResults = reportingDatabase.getArtifactResults( artifact );
assertEquals( 1, reportingDatabase.getNumNotices() );
assertEquals( 1, artifactResults.getNotices().size() );
}
public void testAddWarningArtifactStringStringString()
{
reportingDatabase.addWarning( artifact, processor, problem, reason );
ArtifactResults artifactResults = reportingDatabase.getArtifactResults( artifact );
assertEquals( 1, reportingDatabase.getNumWarnings() );
assertEquals( 1, artifactResults.getWarnings().size() );
reportingDatabase.addWarning( artifact, processor, problem, reason );
artifactResults = reportingDatabase.getArtifactResults( artifact );
assertEquals( 1, reportingDatabase.getNumWarnings() );
assertEquals( 1, artifactResults.getWarnings().size() );
}
public void testAddFailureArtifactStringStringString()
{
reportingDatabase.addFailure( artifact, processor, problem, reason );
ArtifactResults artifactResults = reportingDatabase.getArtifactResults( artifact );
assertEquals( 1, reportingDatabase.getNumFailures() );
assertEquals( 1, artifactResults.getFailures().size() );
reportingDatabase.addFailure( artifact, processor, problem, reason );
artifactResults = reportingDatabase.getArtifactResults( artifact );
assertEquals( 1, reportingDatabase.getNumFailures() );
assertEquals( 1, artifactResults.getFailures().size() );
}
public void testAddNoticeRepositoryMetadataStringStringString()
{
reportingDatabase.addNotice( metadata, processor, problem, reason );
MetadataResults metadataResults = reportingDatabase.getMetadataResults( metadata, System.currentTimeMillis() );
assertEquals( 1, reportingDatabase.getNumNotices() );
assertEquals( 1, metadataResults.getNotices().size() );
reportingDatabase.addNotice( metadata, processor, problem, reason );
metadataResults = reportingDatabase.getMetadataResults( metadata, System.currentTimeMillis() );
assertEquals( 1, reportingDatabase.getNumNotices() );
assertEquals( 1, metadataResults.getNotices().size() );
}
public void testAddWarningRepositoryMetadataStringStringString()
{
reportingDatabase.addWarning( metadata, processor, problem, reason );
MetadataResults metadataResults = reportingDatabase.getMetadataResults( metadata, System.currentTimeMillis() );
assertEquals( 1, reportingDatabase.getNumWarnings() );
assertEquals( 1, metadataResults.getWarnings().size() );
reportingDatabase.addWarning( metadata, processor, problem, reason );
metadataResults = reportingDatabase.getMetadataResults( metadata, System.currentTimeMillis() );
assertEquals( 1, reportingDatabase.getNumWarnings() );
assertEquals( 1, metadataResults.getWarnings().size() );
}
public void testAddFailureRepositoryMetadataStringStringString()
{
reportingDatabase.addFailure( metadata, processor, problem, reason );
MetadataResults metadataResults = reportingDatabase.getMetadataResults( metadata, System.currentTimeMillis() );
assertEquals( 1, reportingDatabase.getNumFailures() );
assertEquals( 1, metadataResults.getFailures().size() );
reportingDatabase.addFailure( metadata, processor, problem, reason );
metadataResults = reportingDatabase.getMetadataResults( metadata, System.currentTimeMillis() );
assertEquals( 1, reportingDatabase.getNumFailures() );
assertEquals( 1, metadataResults.getFailures().size() );
}
}