/*
* 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 legal-notices/CDDLv1_0.txt
* or http://forgerock.org/license/CDDLv1.0.html.
* 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 legal-notices/CDDLv1_0.txt.
* 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.forgerock.opendj.config;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.when;
import org.forgerock.opendj.config.server.ServerManagedObject;
import org.forgerock.opendj.config.server.ServerManagementContext;
import org.forgerock.opendj.config.server.spi.ConfigurationRepository;
import org.forgerock.opendj.ldap.Entry;
import org.forgerock.opendj.ldif.LDIF;
import org.forgerock.opendj.server.config.server.RootCfg;
import org.testng.annotations.Test;
/**
* An abstract class that all admin unit tests should extend.
*/
@SuppressWarnings("javadoc")
@Test(groups = { "precommit", "admin" }, singleThreaded = true)
public abstract class AdminTestCase extends ConfigTestCase {
/**
* Create a mock of ConfigurationRepository with provided entries registered.
*/
protected final ConfigurationRepository createConfigRepositoryWithEntries(final Entry...entries) throws Exception {
ConfigurationRepository configRepository = mock(ConfigurationRepository.class);
for (Entry entry : entries) {
when(configRepository.getEntry(entry.getName())).thenReturn(entry);
when(configRepository.hasEntry(entry.getName())).thenReturn(true);
}
return configRepository;
}
/** Returns the name used for the provided entry (the value of the cn attribute). */
protected final String entryName(final Entry entry) {
return entry.getName().rdn().getFirstAVA().getAttributeValue().toString();
}
/** Gets the named parent configuration corresponding to the provided entry. */
protected final TestParentCfg getParentCfg(final Entry entry, final ServerManagementContext serverContext)
throws Exception {
return getParentCfg(entryName(entry), serverContext);
}
/** Gets the named parent configuration corresponding to provided name. */
protected final TestParentCfg getParentCfg(final String name, final ServerManagementContext serverContext)
throws Exception {
ServerManagedObject<RootCfg> root = serverContext.getRootConfigurationManagedObject();
return root.getChild(TestCfg.getTestOneToManyParentRelationDefinition(), name).getConfiguration();
}
protected static final Entry CONFIG_ENTRY = LDIF.makeEntry(
"dn: cn=config",
"objectclass: top",
"objectclass: ds-cfg-branch",
"cn: config");
protected static final Entry CONN_HANDLER_ENTRY = LDIF.makeEntry(
"dn: cn=Connection Handlers,cn=config",
"objectClass: top",
"objectClass: ds-cfg-branch",
"cn: Connection Handlers");
protected static final Entry LDAP_CONN_HANDLER_ENTRY = LDIF.makeEntry(
"dn: cn=LDAP Connection Handler,cn=Connection Handlers,cn=config",
"objectClass: top",
"objectClass: ds-cfg-connection-handler",
"objectClass: ds-cfg-ldap-connection-handler",
"cn: LDAP Connection Handler",
"ds-cfg-java-class: org.opends.server.protocols.ldap.LDAPConnectionHandler",
"ds-cfg-enabled: true",
"ds-cfg-listen-address: 0.0.0.0", "ds-cfg-listen-port: 389");
protected static final Entry LDAPS_CONN_HANDLER_ENTRY = LDIF.makeEntry(
"dn: cn=LDAPS Connection Handler,cn=Connection Handlers,cn=config",
"objectClass: top",
"objectClass: ds-cfg-connection-handler",
"objectClass: ds-cfg-ldap-connection-handler",
"cn: LDAPS Connection Handler",
"ds-cfg-java-class: org.opends.server.protocols.ldap.LDAPConnectionHandler",
"ds-cfg-enabled: false",
"ds-cfg-listen-address: 0.0.0.0",
"ds-cfg-listen-port: 636",
"ds-cfg-use-ssl: true",
"ds-cfg-ssl-client-auth-policy: optional",
"ds-cfg-ssl-cert-nickname: server-cert",
"ds-cfg-key-manager-provider: cn=JKS,cn=Key Manager Providers,cn=config",
"ds-cfg-trust-manager-provider: cn=JKS,cn=Trust Manager Providers,cn=config");
protected static final Entry JMX_CONN_HANDLER_ENTRY = LDIF.makeEntry(
"dn: cn=JMX Connection Handler,cn=Connection Handlers,cn=config",
"objectClass: top",
"objectClass: ds-cfg-connection-handler",
"objectClass: ds-cfg-jmx-connection-handler",
"cn: JMX Connection Handler",
"ds-cfg-java-class: org.opends.server.protocols.jmx.JmxConnectionHandler",
"ds-cfg-enabled: false",
"ds-cfg-listen-port: 1689");
}