blob: 546ccea0d5b696b69cabdfde14f1ca701a4c0c78 [file] [log] [blame]
/*
* 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<String,Object> createEnvironment(
Hashtable<String, Object> 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<MutablePartitionConfiguration> partitions =
new HashSet<MutablePartitionConfiguration> ();
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<String, Object> env =
new Hashtable<String, Object>();
return new InitialLdapContext(
createEnvironment(env, partitionName), null);
}
public void setUp() throws Exception
{
super.setUp();
}
}