/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License, Version 1.0 only * (the "License"). You may not use this file except in compliance * with the License. * * You can obtain a copy of the license at * trunk/opends/resource/legal-notices/OpenDS.LICENSE * or https://OpenDS.dev.java.net/OpenDS.LICENSE. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at * trunk/opends/resource/legal-notices/OpenDS.LICENSE. If applicable, * add the following below this CDDL HEADER, with the fields enclosed * by brackets "[]" replaced with your own identifying information: * Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END * * * Copyright 2008 Sun Microsystems, Inc. */ package org.opends.server.admin.server; import java.util.Collection; import java.util.Collections; import org.opends.messages.Message; import org.opends.server.admin.Constraint; import org.opends.server.admin.client.ClientConstraintHandler; import org.opends.server.config.ConfigEntry; import org.opends.server.config.ConfigException; import org.opends.server.core.DirectoryServer; import org.opends.server.types.DN; import org.testng.Assert; /** * A mock constraint which can be configured to refuse various types * of operation. */ public final class MockConstraint extends Constraint { /** * Mock server constraint handler. */ private class Handler extends ServerConstraintHandler { /** * {@inheritDoc} */ @Override public boolean isDeleteAllowed(ServerManagedObject<?> managedObject, Collection<Message> unacceptableReasons) throws ConfigException { if (!isDeleteAllowed) { unacceptableReasons .add(Message.raw("Configuration cannot be deleted.")); } return isDeleteAllowed; } /** * {@inheritDoc} */ @Override public boolean isUsable(ServerManagedObject<?> managedObject, Collection<Message> unacceptableReasons) throws ConfigException { if (!isUsable) { unacceptableReasons.add(Message.raw("Configuration is not usable.")); } return isUsable; } /** * {@inheritDoc} */ @Override public void performPostAdd(ServerManagedObject<?> managedObject) throws ConfigException { // Make sure that the associated config entry exists. DN targetDN = managedObject.getDN(); ConfigEntry configEntry = DirectoryServer.getConfigEntry(targetDN); Assert.assertNotNull(configEntry); } /** * {@inheritDoc} */ @Override public void performPostDelete(ServerManagedObject<?> managedObject) throws ConfigException { // Make sure that the associated config entry does not exist. DN targetDN = managedObject.getDN(); ConfigEntry configEntry = DirectoryServer.getConfigEntry(targetDN); Assert.assertNull(configEntry); } /** * {@inheritDoc} */ @Override public void performPostModify(ServerManagedObject<?> managedObject) throws ConfigException { // Make sure that the associated config entry exists. DN targetDN = managedObject.getDN(); ConfigEntry configEntry = DirectoryServer.getConfigEntry(targetDN); Assert.assertNotNull(configEntry); } } // Determines if delete operations are allowed. private final boolean isDeleteAllowed; // Determines if configurations can be decoded. private final boolean isUsable; /** * Creates a new mock constraint. * * @param isUsable * Determines if configurations can be decoded. * @param isDeleteAllowed * Determines if delete operations are allowed. */ public MockConstraint(boolean isUsable, boolean isDeleteAllowed) { this.isUsable = isUsable; this.isDeleteAllowed = isDeleteAllowed; } /** * {@inheritDoc} */ public Collection<ClientConstraintHandler> getClientConstraintHandlers() { return Collections.emptySet(); } /** * {@inheritDoc} */ public Collection<ServerConstraintHandler> getServerConstraintHandlers() { return Collections.<ServerConstraintHandler> singleton(new Handler()); } }