From d20cce3a52f5a983ced1ab9da36fa91999f8a6f5 Mon Sep 17 00:00:00 2001 From: "Jevica Arianne B. Zurbano" Date: Thu, 10 Sep 2009 13:50:40 +0000 Subject: [MRM-1240] - NPE when updating consumers (not setting any of the checkboxes) of Unprocessed Artifacts and Artifact Cleanup Scanning in Database - added null checks - added unit test for DatabaseAction Submitted by: Gwen Harold Autencio git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@813439 13f79535-47bb-0310-9956-ffa450edef68 --- .../web/action/admin/database/DatabaseAction.java | 40 ++++- .../action/admin/database/DatabaseActionTest.java | 184 +++++++++++++++++++++ 2 files changed, 220 insertions(+), 4 deletions(-) create mode 100644 archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/admin/database/DatabaseActionTest.java diff --git a/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/database/DatabaseAction.java b/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/database/DatabaseAction.java index 9c7d1b518..7515fc2aa 100644 --- a/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/database/DatabaseAction.java +++ b/archiva-modules/archiva-web/archiva-webapp/src/main/java/org/apache/maven/archiva/web/action/admin/database/DatabaseAction.java @@ -110,8 +110,15 @@ public class DatabaseAction archivaConfiguration.getConfiguration().getDatabaseScanning().setUnprocessedConsumers( enabledUnprocessedConsumers ); - filterAddedConsumers( oldConsumers, enabledUnprocessedConsumers ); - filterRemovedConsumers( oldConsumers, enabledUnprocessedConsumers ); + if ( enabledUnprocessedConsumers != null ) + { + filterAddedConsumers( oldConsumers, enabledUnprocessedConsumers ); + filterRemovedConsumers( oldConsumers, enabledUnprocessedConsumers ); + } + else + { + disableAllEnabledConsumers( oldConsumers ); + } return saveConfiguration(); } @@ -122,8 +129,15 @@ public class DatabaseAction archivaConfiguration.getConfiguration().getDatabaseScanning().setCleanupConsumers( enabledCleanupConsumers ); - filterAddedConsumers( oldConsumers, enabledCleanupConsumers ); - filterRemovedConsumers( oldConsumers, enabledCleanupConsumers ); + if ( enabledCleanupConsumers != null ) + { + filterAddedConsumers( oldConsumers, enabledCleanupConsumers ); + filterRemovedConsumers( oldConsumers, enabledCleanupConsumers ); + } + else + { + disableAllEnabledConsumers( oldConsumers ); + } return saveConfiguration(); } @@ -215,6 +229,16 @@ public class DatabaseAction this.enabledCleanupConsumers = enabledCleanupConsumers; } + public ArchivaConfiguration getArchivaConfiguration() + { + return archivaConfiguration; + } + + public void setArchivaConfiguration( ArchivaConfiguration archivaConfiguration ) + { + this.archivaConfiguration = archivaConfiguration; + } + private void filterAddedConsumers( List oldList, List newList ) { for ( String consumer : newList ) @@ -236,4 +260,12 @@ public class DatabaseAction } } } + + private void disableAllEnabledConsumers( List enabledConsumers ) + { + for( String consumer : enabledConsumers ) + { + triggerAuditEvent( consumer, AuditEvent.DISABLE_DB_CONSUMER ); + } + } } diff --git a/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/admin/database/DatabaseActionTest.java b/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/admin/database/DatabaseActionTest.java new file mode 100644 index 000000000..a47535ea5 --- /dev/null +++ b/archiva-modules/archiva-web/archiva-webapp/src/test/java/org/apache/maven/archiva/web/action/admin/database/DatabaseActionTest.java @@ -0,0 +1,184 @@ +package org.apache.maven.archiva.web.action.admin.database; + +/* + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you 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 java.util.ArrayList; +import java.util.List; + +import org.apache.maven.archiva.configuration.ArchivaConfiguration; +import org.apache.maven.archiva.configuration.Configuration; +import org.apache.maven.archiva.configuration.DatabaseScanningConfiguration; +import org.codehaus.plexus.spring.PlexusInSpringTestCase; +import org.easymock.MockControl; + +/** + * DatabaseActionTest + */ +public class DatabaseActionTest + extends PlexusInSpringTestCase +{ + private DatabaseAction action; + + private MockControl archivaConfigControl; + + private ArchivaConfiguration archivaConfig; + + private Configuration config; + + protected void setUp() + throws Exception + { + super.setUp(); + + archivaConfigControl = MockControl.createControl( ArchivaConfiguration.class ); + archivaConfig = (ArchivaConfiguration) archivaConfigControl.getMock(); + + action = new DatabaseAction(); + + config = new Configuration(); + + DatabaseScanningConfiguration databaseScanningConfig = new DatabaseScanningConfiguration(); + + List cleanUpConsumers = new ArrayList(); + cleanUpConsumers.add( "not-present-remove-db-artifact" ); + cleanUpConsumers.add( "not-present-remove-db-project" ); + cleanUpConsumers.add( "not-present-remove-indexed" ); + + List unprocessedConsumers = new ArrayList(); + unprocessedConsumers.add( "update-db-bytecode-stats" ); + unprocessedConsumers.add( "update-db-project" ); + unprocessedConsumers.add( "validate-repository-metadata" ); + + databaseScanningConfig.setCleanupConsumers( cleanUpConsumers ); + databaseScanningConfig.setUnprocessedConsumers( unprocessedConsumers ); + + config.setDatabaseScanning( databaseScanningConfig ); + + setUpEnabledUnproccessedConsumers(); + setUpEnabledCleanupConsumers(); + + action.setArchivaConfiguration( archivaConfig ); + } + + protected void tearDown() + throws Exception + { + super.tearDown(); + } + + public void testUpdateUnprocessedConsumers() + throws Exception + { + archivaConfigControl.expectAndReturn( archivaConfig.getConfiguration(), config ); + archivaConfigControl.expectAndReturn( archivaConfig.getConfiguration(), config ); + archivaConfigControl.expectAndReturn( archivaConfig.getConfiguration(), config ); + + archivaConfig.save( config ); + archivaConfigControl.replay(); + + String returnString = action.updateUnprocessedConsumers(); + + List results = config.getDatabaseScanning().getUnprocessedConsumers(); + + assertEquals( action.SUCCESS, returnString ); + assertEquals( 3, results.size() ); + } + + public void testUpdateCleanUpConsumers() + throws Exception + { + archivaConfigControl.expectAndReturn( archivaConfig.getConfiguration(), config ); + archivaConfigControl.expectAndReturn( archivaConfig.getConfiguration(), config ); + archivaConfigControl.expectAndReturn( archivaConfig.getConfiguration(), config ); + + archivaConfig.save( config ); + archivaConfigControl.replay(); + + String returnString = action.updateCleanupConsumers(); + + List results = config.getDatabaseScanning().getCleanupConsumers(); + + assertEquals( action.SUCCESS, returnString ); + assertEquals( 3, results.size() ); + } + + public void testDisableAllUnprocessedConsumers( ) + throws Exception + { + archivaConfigControl.expectAndReturn( archivaConfig.getConfiguration(), config ); + archivaConfigControl.expectAndReturn( archivaConfig.getConfiguration(), config ); + archivaConfigControl.expectAndReturn( archivaConfig.getConfiguration(), config ); + + archivaConfig.save( config ); + archivaConfigControl.replay(); + + action.setEnabledUnprocessedConsumers( null ); + + String returnString = action.updateUnprocessedConsumers(); + + List results = config.getDatabaseScanning().getUnprocessedConsumers(); + + assertEquals( action.SUCCESS, returnString ); + assertEquals( 0, results.size() ); + } + + public void testDisableAllCleanupConsumers( ) + throws Exception + { + archivaConfigControl.expectAndReturn( archivaConfig.getConfiguration(), config ); + archivaConfigControl.expectAndReturn( archivaConfig.getConfiguration(), config ); + archivaConfigControl.expectAndReturn( archivaConfig.getConfiguration(), config ); + + archivaConfig.save( config ); + archivaConfigControl.replay(); + + action.setEnabledCleanupConsumers( null ); + + String returnString = action.updateCleanupConsumers(); + + List results = config.getDatabaseScanning().getCleanupConsumers(); + + assertEquals( action.SUCCESS, returnString ); + assertEquals( 0, results.size() ); + } + + private void setUpEnabledUnproccessedConsumers( ) + { + List enabledUnprocessedConsumer = new ArrayList(); + + enabledUnprocessedConsumer.add( "update-db-bytecode-stats" ); + enabledUnprocessedConsumer.add( "update-db-project" ); + enabledUnprocessedConsumer.add( "validate-repository-metadata" ); + + action.setEnabledUnprocessedConsumers( enabledUnprocessedConsumer ); + } + + private void setUpEnabledCleanupConsumers( ) + { + List enabledCleanupConsumers = new ArrayList(); + + enabledCleanupConsumers.add( "not-present-remove-db-artifact" ); + enabledCleanupConsumers.add( "not-present-remove-db-project" ); + enabledCleanupConsumers.add( "not-present-remove-indexed" ); + + action.setEnabledCleanupConsumers( enabledCleanupConsumers ); + } + +} -- cgit v1.2.3