/* * 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. * */ package org.apache.directory.apacheds.testing.setup; import java.util.HashSet; import java.util.Hashtable; import java.util.Set; import javax.naming.Context; import javax.naming.NamingException; import javax.naming.directory.Attributes; import javax.naming.directory.BasicAttributes; import javax.naming.ldap.InitialLdapContext; import javax.naming.ldap.LdapContext; import org.apache.directory.server.core.configuration.Configuration; import org.apache.directory.server.core.configuration.MutablePartitionConfiguration; import org.apache.directory.server.core.configuration.MutableStartupConfiguration; import org.apache.tuscany.das.ldap.constants.ApacheDSConnectionConstants; import org.apache.tuscany.das.ldap.schema.embedded.setup.test.AbstractTestSetup; import junit.framework.TestCase; /* * Just a class template class */ public abstract class JNDIHotPartitionConnectionTemplate extends AbstractTestSetup implements ApacheDSConnectionConstants { public Hashtable createEnvironment( Hashtable env, String partitionName) throws NamingException { MutableStartupConfiguration mutableStartupConfiguration = new MutableStartupConfiguration(); MutablePartitionConfiguration dasPartition = new MutablePartitionConfiguration(); Attributes suffixAttributes = new BasicAttributes(); suffixAttributes.put( "objectClass", "top"); suffixAttributes.get( "objectClass" ).add( "organizationalUnit" ); suffixAttributes.put( "ou", partitionName ); dasPartition.setId( partitionName); dasPartition.setSuffix( "ou=" +partitionName ); dasPartition.setContextEntry( suffixAttributes ); Set partitions = new HashSet (); partitions.add( dasPartition ); mutableStartupConfiguration. setPartitionConfigurations( partitions ); env.put( Context.INITIAL_CONTEXT_FACTORY, "org.apache.directory.server.core.jndi.CoreContextFactory" ); env.put( Context.SECURITY_PRINCIPAL, DEFAULT_SECURITY_PRINCIPAL_VALUE); env.put( Context.SECURITY_CREDENTIALS, DEFAULT_SECURITY_CREDENTIALS_VALUE); env.put( Context.SECURITY_AUTHENTICATION, SIMPLE_SECURITY_AUTHENTICATION_VALUE ); env.put( Context.PROVIDER_URL, "ou=" + partitionName ); env.put( Configuration.JNDI_KEY, mutableStartupConfiguration ); return env; } public LdapContext connect( String partitionName ) throws NamingException { Hashtable env = new Hashtable(); return new InitialLdapContext( createEnvironment(env, partitionName), null); } public void setUp() throws Exception { super.setUp(); } }