/* * Copyright 2014 Red Hat, Inc. and/or its affiliates. * * Licensed 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.jbpm.services.task.identity; import com.unboundid.ldap.listener.InMemoryDirectoryServer; import com.unboundid.ldap.listener.InMemoryDirectoryServerConfig; import com.unboundid.ldap.listener.InMemoryListenerConfig; import com.unboundid.ldap.sdk.DN; import com.unboundid.ldap.sdk.LDAPException; import org.junit.After; import org.junit.Before; public abstract class LDAPBaseTest { private static final int PORT = 10389; protected static final String SERVER_URL = "ldap://localhost:" + PORT; protected static final String BASE_DN = "dc=jbpm,dc=org"; protected static final String USER_DN = "uid=admin,ou=system"; protected static final String PASSWORD = "secret"; public enum Configuration { CUSTOM, DEFAULT, SYSTEM } private InMemoryDirectoryServer server; @Before public void startDirectoryServer() throws LDAPException { InMemoryListenerConfig listenerConfig = InMemoryListenerConfig.createLDAPConfig("default", PORT); InMemoryDirectoryServerConfig serverConfig = new InMemoryDirectoryServerConfig(new DN(BASE_DN)); serverConfig.setListenerConfigs(listenerConfig); serverConfig.addAdditionalBindCredentials(USER_DN, PASSWORD); serverConfig.setSchema(null); server = new InMemoryDirectoryServer(serverConfig); server.importFromLDIF(false, "src/test/resources/ldap-config.ldif"); server.startListening(); } @After public void stopDirectoryServer() { if (server != null) { server.shutDown(true); } } }