diff --git a/archiva-reports-standard/src/main/java/org/apache/maven/archiva/reporting/database/ReportingDatabase.java b/archiva-reports-standard/src/main/java/org/apache/maven/archiva/reporting/database/ReportingDatabase.java index b00982570..c477cf03a 100644 --- a/archiva-reports-standard/src/main/java/org/apache/maven/archiva/reporting/database/ReportingDatabase.java +++ b/archiva-reports-standard/src/main/java/org/apache/maven/archiva/reporting/database/ReportingDatabase.java @@ -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 ) ); - numFailures++; + 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 ) ); - numNotices++; + 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 ) ); - numWarnings++; + 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 ) ); - numFailures++; + 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 ) ); - numWarnings++; + 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 ) ); - numNotices++; + 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 ); diff --git a/archiva-reports-standard/src/main/mdo/reporting.mdo b/archiva-reports-standard/src/main/mdo/reporting.mdo index 427fc95bf..1f7326c6f 100644 --- a/archiva-reports-standard/src/main/mdo/reporting.mdo +++ b/archiva-reports-standard/src/main/mdo/reporting.mdo @@ -238,6 +238,41 @@ + + + + 1.0.0 + + + + diff --git a/archiva-reports-standard/src/test/java/org/apache/maven/archiva/reporting/database/ReportingDatabaseTest.java b/archiva-reports-standard/src/test/java/org/apache/maven/archiva/reporting/database/ReportingDatabaseTest.java new file mode 100644 index 000000000..90278fdf2 --- /dev/null +++ b/archiva-reports-standard/src/test/java/org/apache/maven/archiva/reporting/database/ReportingDatabaseTest.java @@ -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 Carlos Sanchez + * @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() ); + } +}