| /* |
| * 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.server.core.partition.avl; |
| |
| |
| import static org.junit.Assert.assertEquals; |
| import static org.junit.Assert.assertFalse; |
| import static org.junit.Assert.assertNotNull; |
| import static org.junit.Assert.assertNull; |
| import static org.junit.Assert.assertTrue; |
| import static org.junit.Assert.fail; |
| |
| import java.io.File; |
| import java.lang.reflect.Method; |
| import java.util.ArrayList; |
| import java.util.HashSet; |
| import java.util.Iterator; |
| import java.util.List; |
| import java.util.Set; |
| import java.util.UUID; |
| |
| import javax.naming.directory.Attributes; |
| |
| import org.apache.directory.server.constants.ApacheSchemaConstants; |
| import org.apache.directory.server.xdbm.GenericIndex; |
| import org.apache.directory.server.xdbm.Index; |
| import org.apache.directory.server.xdbm.IndexEntry; |
| import org.apache.directory.server.xdbm.IndexNotFoundException; |
| import org.apache.directory.server.xdbm.tools.StoreUtils; |
| import org.apache.directory.shared.ldap.constants.SchemaConstants; |
| import org.apache.directory.shared.ldap.csn.CsnFactory; |
| import org.apache.directory.shared.ldap.cursor.Cursor; |
| import org.apache.directory.shared.ldap.entry.DefaultServerAttribute; |
| import org.apache.directory.shared.ldap.entry.DefaultServerEntry; |
| import org.apache.directory.shared.ldap.entry.EntryAttribute; |
| import org.apache.directory.shared.ldap.entry.Modification; |
| import org.apache.directory.shared.ldap.entry.ModificationOperation; |
| import org.apache.directory.shared.ldap.entry.ServerEntry; |
| import org.apache.directory.shared.ldap.entry.ServerModification; |
| import org.apache.directory.shared.ldap.exception.LdapNoSuchObjectException; |
| import org.apache.directory.shared.ldap.exception.LdapSchemaViolationException; |
| import org.apache.directory.shared.ldap.name.DN; |
| import org.apache.directory.shared.ldap.name.RDN; |
| import org.apache.directory.shared.ldap.schema.SchemaManager; |
| import org.apache.directory.shared.ldap.schema.ldif.extractor.SchemaLdifExtractor; |
| import org.apache.directory.shared.ldap.schema.ldif.extractor.impl.DefaultSchemaLdifExtractor; |
| import org.apache.directory.shared.ldap.schema.loader.ldif.LdifSchemaLoader; |
| import org.apache.directory.shared.ldap.schema.manager.impl.DefaultSchemaManager; |
| import org.apache.directory.shared.ldap.util.ExceptionUtils; |
| import org.junit.After; |
| import org.junit.Before; |
| import org.junit.BeforeClass; |
| import org.junit.Test; |
| import org.slf4j.Logger; |
| import org.slf4j.LoggerFactory; |
| |
| |
| /** |
| * Unit test cases for AvlStore |
| * |
| * @author <a href="mailto:dev@directory.apache.org">Apache Directory Project</a> |
| * @version $$Rev$$ |
| */ |
| @SuppressWarnings("unchecked") |
| public class AvlStoreTest |
| { |
| private static final Logger LOG = LoggerFactory.getLogger( AvlStoreTest.class.getSimpleName() ); |
| |
| private static File wkdir; |
| private static AvlStore<ServerEntry> store; |
| private static SchemaManager schemaManager = null; |
| |
| |
| @BeforeClass |
| public static void setup() throws Exception |
| { |
| String workingDirectory = System.getProperty( "workingDirectory" ); |
| |
| if ( workingDirectory == null ) |
| { |
| String path = AvlStoreTest.class.getResource( "" ).getPath(); |
| int targetPos = path.indexOf( "target" ); |
| workingDirectory = path.substring( 0, targetPos + 6 ); |
| } |
| |
| File schemaRepository = new File( workingDirectory, "schema" ); |
| SchemaLdifExtractor extractor = new DefaultSchemaLdifExtractor( new File( workingDirectory ) ); |
| extractor.extractOrCopy( true ); |
| LdifSchemaLoader loader = new LdifSchemaLoader( schemaRepository ); |
| |
| schemaManager = new DefaultSchemaManager( loader ); |
| |
| boolean loaded = schemaManager.loadAllEnabled(); |
| |
| if ( !loaded ) |
| { |
| fail( "Schema load failed : " + ExceptionUtils.printErrors( schemaManager.getErrors() ) ); |
| } |
| } |
| |
| |
| @Before |
| public void createStore() throws Exception |
| { |
| destroyStore(); |
| |
| // setup the working directory for the store |
| wkdir = File.createTempFile( getClass().getSimpleName(), "db" ); |
| wkdir.delete(); |
| wkdir = new File( wkdir.getParentFile(), getClass().getSimpleName() ); |
| wkdir.mkdirs(); |
| |
| // initialize the store |
| store = new AvlStore<ServerEntry>(); |
| store.setName( "example" ); |
| store.setSyncOnWrite( false ); |
| |
| store.addIndex( new AvlIndex( SchemaConstants.OU_AT_OID ) ); |
| store.addIndex( new AvlIndex( SchemaConstants.UID_AT_OID ) ); |
| StoreUtils.loadExampleData( store, schemaManager ); |
| LOG.debug( "Created new store" ); |
| } |
| |
| |
| @After |
| public void destroyStore() throws Exception |
| { |
| } |
| |
| |
| @Test |
| public void testSimplePropertiesUnlocked() throws Exception |
| { |
| AvlStore<Attributes> store = new AvlStore<Attributes>(); |
| store.setSyncOnWrite( true ); // for code coverage |
| |
| assertNull( store.getAliasIndex() ); |
| store.setAliasIndex( new AvlIndex<String, Attributes>( "alias" ) ); |
| assertNotNull( store.getAliasIndex() ); |
| |
| assertEquals( 0, store.getCacheSize() ); |
| |
| assertNull( store.getPresenceIndex() ); |
| store.setPresenceIndex( new AvlIndex<String, Attributes>( "existence" ) ); |
| assertNotNull( store.getPresenceIndex() ); |
| |
| assertNull( store.getOneLevelIndex() ); |
| store.setOneLevelIndex( new AvlIndex<Long, Attributes>( "hierarchy" ) ); |
| assertNotNull( store.getOneLevelIndex() ); |
| |
| assertNull( store.getSubLevelIndex() ); |
| store.setSubLevelIndex( new AvlIndex<Long, Attributes>( "sublevel" ) ); |
| assertNotNull( store.getSubLevelIndex() ); |
| |
| assertNull( store.getName() ); |
| store.setName( "foo" ); |
| assertEquals( "foo", store.getName() ); |
| |
| assertNull( store.getNdnIndex() ); |
| store.setNdnIndex( new AvlIndex<String, Attributes>( "ndn" ) ); |
| assertNotNull( store.getNdnIndex() ); |
| |
| assertNull( store.getOneAliasIndex() ); |
| store.setOneAliasIndex( new AvlIndex<Long, Attributes>( "oneAlias" ) ); |
| assertNotNull( store.getNdnIndex() ); |
| |
| assertNull( store.getSubAliasIndex() ); |
| store.setSubAliasIndex( new AvlIndex<Long, Attributes>( "subAlias" ) ); |
| assertNotNull( store.getSubAliasIndex() ); |
| |
| assertNull( store.getSuffixDn() ); |
| store.setSuffixDn( "dc=example,dc=com" ); |
| assertEquals( "dc=example,dc=com", store.getSuffixDn() ); |
| |
| assertNull( store.getUpdnIndex() ); |
| store.setUpdnIndex( new AvlIndex<String, Attributes>( "updn" ) ); |
| assertNotNull( store.getUpdnIndex() ); |
| |
| assertNotNull( store.getUpSuffix() ); |
| assertNotNull( store.getSuffix() ); |
| |
| assertEquals( 0, store.getUserIndices().size() ); |
| Set<Index<?, Attributes, Long>> set = new HashSet<Index<?, Attributes, Long>>(); |
| set.add( new AvlIndex<Object, Attributes>( "foo" ) ); |
| store.setUserIndices( set ); |
| assertEquals( set.size(), store.getUserIndices().size() ); |
| |
| assertNull( store.getWorkingDirectory() ); |
| store.setWorkingDirectory( new File( "." ) ); |
| assertNull( store.getWorkingDirectory() ); |
| |
| assertFalse( store.isInitialized() ); |
| assertFalse( store.isSyncOnWrite() ); |
| store.setSyncOnWrite( false ); |
| assertFalse( store.isSyncOnWrite() ); |
| |
| store.sync(); |
| store.destroy(); |
| } |
| |
| |
| @Test |
| public void testSimplePropertiesLocked() throws Exception |
| { |
| assertNotNull( store.getAliasIndex() ); |
| try |
| { |
| store.setAliasIndex( new AvlIndex<String, ServerEntry>( "alias" ) ); |
| fail(); |
| } |
| catch ( IllegalStateException e ) |
| { |
| } |
| |
| assertEquals( 0, store.getCacheSize() ); |
| |
| assertNotNull( store.getPresenceIndex() ); |
| try |
| { |
| store.setPresenceIndex( new AvlIndex<String, ServerEntry>( "existence" ) ); |
| fail(); |
| } |
| catch ( IllegalStateException e ) |
| { |
| } |
| |
| assertNotNull( store.getOneLevelIndex() ); |
| try |
| { |
| store.setOneLevelIndex( new AvlIndex<Long, ServerEntry>( "hierarchy" ) ); |
| fail(); |
| } |
| catch ( IllegalStateException e ) |
| { |
| } |
| |
| assertNotNull( store.getSubLevelIndex() ); |
| try |
| { |
| store.setSubLevelIndex( new AvlIndex<Long, ServerEntry>( "sublevel" ) ); |
| fail(); |
| } |
| catch ( IllegalStateException e ) |
| { |
| } |
| |
| assertNotNull( store.getName() ); |
| try |
| { |
| store.setName( "foo" ); |
| fail(); |
| } |
| catch ( IllegalStateException e ) |
| { |
| } |
| |
| assertNotNull( store.getNdnIndex() ); |
| try |
| { |
| store.setNdnIndex( new AvlIndex<String, ServerEntry>( "ndn" ) ); |
| fail(); |
| } |
| catch ( IllegalStateException e ) |
| { |
| } |
| |
| assertNotNull( store.getOneAliasIndex() ); |
| try |
| { |
| store.setOneAliasIndex( new AvlIndex<Long, ServerEntry>( "oneAlias" ) ); |
| fail(); |
| } |
| catch ( IllegalStateException e ) |
| { |
| } |
| |
| assertNotNull( store.getSubAliasIndex() ); |
| try |
| { |
| store.setSubAliasIndex( new AvlIndex<Long, ServerEntry>( "subAlias" ) ); |
| fail(); |
| } |
| catch ( IllegalStateException e ) |
| { |
| } |
| |
| assertNotNull( store.getSuffixDn() ); |
| try |
| { |
| store.setSuffixDn( "dc=example,dc=com" ); |
| fail(); |
| } |
| catch ( IllegalStateException e ) |
| { |
| } |
| |
| assertNotNull( store.getUpdnIndex() ); |
| try |
| { |
| store.setUpdnIndex( new AvlIndex<String, ServerEntry>( "updn" ) ); |
| fail(); |
| } |
| catch ( IllegalStateException e ) |
| { |
| } |
| Iterator<String> systemIndices = store.systemIndices(); |
| |
| for ( int ii = 0; ii < 11; ii++ ) |
| { |
| assertTrue( systemIndices.hasNext() ); |
| assertNotNull( systemIndices.next() ); |
| } |
| |
| assertFalse( systemIndices.hasNext() ); |
| assertNotNull( store.getSystemIndex( ApacheSchemaConstants.APACHE_ALIAS_AT_OID ) ); |
| try |
| { |
| store.getSystemIndex( "bogus" ); |
| fail(); |
| } |
| catch ( IndexNotFoundException e ) |
| { |
| } |
| try |
| { |
| store.getSystemIndex( "dc" ); |
| fail(); |
| } |
| catch ( IndexNotFoundException e ) |
| { |
| } |
| |
| assertNotNull( store.getUpSuffix() ); |
| assertNotNull( store.getSuffix() ); |
| |
| assertEquals( 2, store.getUserIndices().size() ); |
| assertFalse( store.hasUserIndexOn( "dc" ) ); |
| assertTrue( store.hasUserIndexOn( SchemaConstants.OU_AT_OID ) ); |
| assertTrue( store.hasSystemIndexOn( ApacheSchemaConstants.APACHE_ALIAS_AT_OID ) ); |
| Iterator<String> userIndices = store.userIndices(); |
| assertTrue( userIndices.hasNext() ); |
| assertNotNull( userIndices.next() ); |
| assertTrue( userIndices.hasNext() ); |
| assertNotNull( userIndices.next() ); |
| assertFalse( userIndices.hasNext() ); |
| assertNotNull( store.getUserIndex( SchemaConstants.OU_AT_OID ) ); |
| try |
| { |
| store.getUserIndex( "bogus" ); |
| fail(); |
| } |
| catch ( IndexNotFoundException e ) |
| { |
| } |
| try |
| { |
| store.getUserIndex( "dc" ); |
| fail(); |
| } |
| catch ( IndexNotFoundException e ) |
| { |
| } |
| |
| assertNull( store.getWorkingDirectory() ); |
| |
| assertTrue( store.isInitialized() ); |
| assertFalse( store.isSyncOnWrite() ); |
| |
| store.sync(); |
| } |
| |
| |
| @Test |
| public void testPersistentProperties() throws Exception |
| { |
| assertNull( store.getProperty( "foo" ) ); |
| store.setProperty( "foo", "bar" ); |
| assertEquals( "bar", store.getProperty( "foo" ) ); |
| } |
| |
| |
| @Test |
| public void testFreshStore() throws Exception |
| { |
| DN dn = new DN( "o=Good Times Co." ); |
| dn.normalize( schemaManager.getNormalizerMapping() ); |
| assertEquals( 1L, ( long ) store.getEntryId( dn.getNormName() ) ); |
| assertEquals( 11, store.count() ); |
| assertEquals( "o=Good Times Co.", store.getEntryUpdn( dn.getNormName() ) ); |
| assertEquals( dn.getNormName(), store.getEntryDn( 1L ) ); |
| assertEquals( dn.getName(), store.getEntryUpdn( 1L ) ); |
| |
| // note that the suffix entry returns 0 for it's parent which does not exist |
| assertEquals( 0L, ( long ) store.getParentId( dn.getNormName() ) ); |
| assertNull( store.getParentId( 0L ) ); |
| |
| // should NOW be allowed |
| store.delete( 1L ); |
| } |
| |
| |
| @Test |
| public void testEntryOperations() throws Exception |
| { |
| assertEquals( 3, store.getChildCount( 1L ) ); |
| |
| Cursor<IndexEntry<Long, ServerEntry, Long>> cursor = store.list( 1L ); |
| assertNotNull( cursor ); |
| cursor.beforeFirst(); |
| assertTrue( cursor.next() ); |
| assertEquals( 2L, ( long ) cursor.get().getId() ); |
| assertTrue( cursor.next() ); |
| assertEquals( 3, store.getChildCount( 1L ) ); |
| |
| store.delete( 2L ); |
| assertEquals( 2, store.getChildCount( 1L ) ); |
| assertEquals( 10, store.count() ); |
| |
| // add an alias and delete to test dropAliasIndices method |
| DN dn = new DN( "commonName=Jack Daniels,ou=Apache,ou=Board of Directors,o=Good Times Co." ); |
| dn.normalize( schemaManager.getNormalizerMapping() ); |
| DefaultServerEntry entry = new DefaultServerEntry( schemaManager, dn ); |
| entry.add( "objectClass", "top", "alias", "extensibleObject" ); |
| entry.add( "ou", "Apache" ); |
| entry.add( "commonName", "Jack Daniels" ); |
| entry.add( "aliasedObjectName", "cn=Jack Daniels,ou=Engineering,o=Good Times Co." ); |
| entry.add( "entryCSN", new CsnFactory( 1 ).newInstance().toString() ); |
| entry.add( "entryUUID", UUID.randomUUID().toString() ); |
| store.add( entry ); |
| |
| store.delete( 12L ); // drops the alias indices |
| |
| } |
| |
| |
| @Test |
| public void testSubLevelIndex() throws Exception |
| { |
| Index idx = store.getSubLevelIndex(); |
| |
| assertEquals( 19, idx.count() ); |
| |
| Cursor<IndexEntry<Long, Attributes, Long>> cursor = idx.forwardCursor( 2L ); |
| |
| assertTrue( cursor.next() ); |
| assertEquals( 2, ( long ) cursor.get().getId() ); |
| |
| assertTrue( cursor.next() ); |
| assertEquals( 5, ( long ) cursor.get().getId() ); |
| |
| assertTrue( cursor.next() ); |
| assertEquals( 6, ( long ) cursor.get().getId() ); |
| |
| assertFalse( cursor.next() ); |
| |
| idx.drop( 5L ); |
| |
| cursor = idx.forwardCursor( 2L ); |
| |
| assertTrue( cursor.next() ); |
| assertEquals( 2, ( long ) cursor.get().getId() ); |
| |
| assertTrue( cursor.next() ); |
| assertEquals( 6, ( long ) cursor.get().getId() ); |
| |
| assertFalse( cursor.next() ); |
| |
| // dn id 12 |
| DN martinDn = new DN( "cn=Marting King,ou=Sales,o=Good Times Co." ); |
| martinDn.normalize( schemaManager.getNormalizerMapping() ); |
| DefaultServerEntry entry = new DefaultServerEntry( schemaManager, martinDn ); |
| entry.add( "objectClass", "top", "person", "organizationalPerson" ); |
| entry.add( "ou", "Sales" ); |
| entry.add( "cn", "Martin King" ); |
| entry.add( "entryCSN", new CsnFactory( 1 ).newInstance().toString() ); |
| entry.add( "entryUUID", UUID.randomUUID().toString() ); |
| store.add( entry ); |
| |
| cursor = idx.forwardCursor( 2L ); |
| cursor.afterLast(); |
| assertTrue( cursor.previous() ); |
| assertEquals( 12, ( long ) cursor.get().getId() ); |
| |
| DN newParentDn = new DN( "ou=Board of Directors,o=Good Times Co." ); |
| newParentDn.normalize( schemaManager.getNormalizerMapping() ); |
| |
| store.move( martinDn, newParentDn ); |
| cursor = idx.forwardCursor( 3L ); |
| cursor.afterLast(); |
| assertTrue( cursor.previous() ); |
| assertEquals( 12, ( long ) cursor.get().getId() ); |
| |
| // dn id 13 |
| DN marketingDn = new DN( "ou=Marketing,ou=Sales,o=Good Times Co." ); |
| marketingDn.normalize( schemaManager.getNormalizerMapping() ); |
| entry = new DefaultServerEntry( schemaManager, marketingDn ); |
| entry.add( "objectClass", "top", "organizationalUnit" ); |
| entry.add( "ou", "Marketing" ); |
| entry.add( "entryCSN", new CsnFactory( 1 ).newInstance().toString() ); |
| entry.add( "entryUUID", UUID.randomUUID().toString() ); |
| store.add( entry ); |
| |
| // dn id 14 |
| DN jimmyDn = new DN( "cn=Jimmy Wales,ou=Marketing, ou=Sales,o=Good Times Co." ); |
| jimmyDn.normalize( schemaManager.getNormalizerMapping() ); |
| entry = new DefaultServerEntry( schemaManager, jimmyDn ); |
| entry.add( "objectClass", "top", "person", "organizationalPerson" ); |
| entry.add( "ou", "Marketing" ); |
| entry.add( "cn", "Jimmy Wales" ); |
| entry.add( "entryCSN", new CsnFactory( 1 ).newInstance().toString() ); |
| entry.add( "entryUUID", UUID.randomUUID().toString() ); |
| store.add( entry ); |
| |
| store.move( marketingDn, newParentDn ); |
| |
| cursor = idx.forwardCursor( 3L ); |
| cursor.afterLast(); |
| |
| assertTrue( cursor.previous() ); |
| assertEquals( 14, ( long ) cursor.get().getId() ); |
| |
| assertTrue( cursor.previous() ); |
| assertEquals( 13, ( long ) cursor.get().getId() ); |
| |
| assertTrue( cursor.previous() ); |
| assertEquals( 12, ( long ) cursor.get().getId() ); |
| |
| assertTrue( cursor.previous() ); |
| assertEquals( 10, ( long ) cursor.get().getId() ); |
| |
| assertTrue( cursor.previous() ); |
| assertEquals( 9, ( long ) cursor.get().getId() ); |
| |
| assertTrue( cursor.previous() ); |
| assertEquals( 7, ( long ) cursor.get().getId() ); |
| |
| assertTrue( cursor.previous() ); |
| assertEquals( 3, ( long ) cursor.get().getId() ); |
| |
| assertFalse( cursor.previous() ); |
| } |
| |
| |
| @Test |
| public void testConvertIndex() throws Exception |
| { |
| Index nonAvlIndex = new GenericIndex( "ou", 10, new File( "." ) ); |
| |
| Method convertIndex = store.getClass().getDeclaredMethod( "convert", Index.class ); |
| convertIndex.setAccessible( true ); |
| Object obj = convertIndex.invoke( store, nonAvlIndex ); |
| |
| assertNotNull( obj ); |
| assertEquals( AvlIndex.class, obj.getClass() ); |
| } |
| |
| |
| @Test(expected = LdapNoSuchObjectException.class) |
| public void testAddWithoutParentId() throws Exception |
| { |
| DN dn = new DN( "cn=Marting King,ou=Not Present,o=Good Times Co." ); |
| dn.normalize( schemaManager.getNormalizerMapping() ); |
| DefaultServerEntry entry = new DefaultServerEntry( schemaManager, dn ); |
| entry.add( "objectClass", "top", "person", "organizationalPerson" ); |
| entry.add( "ou", "Not Present" ); |
| entry.add( "cn", "Martin King" ); |
| store.add( entry ); |
| } |
| |
| |
| @Test(expected = LdapSchemaViolationException.class) |
| public void testAddWithoutObjectClass() throws Exception |
| { |
| DN dn = new DN( "cn=Martin King,ou=Sales,o=Good Times Co." ); |
| dn.normalize( schemaManager.getNormalizerMapping() ); |
| DefaultServerEntry entry = new DefaultServerEntry( schemaManager, dn ); |
| entry.add( "ou", "Sales" ); |
| entry.add( "cn", "Martin King" ); |
| store.add( entry ); |
| } |
| |
| |
| @Test |
| public void testModifyAddOUAttrib() throws Exception |
| { |
| DN dn = new DN( "cn=JOhnny WAlkeR,ou=Sales,o=Good Times Co." ); |
| dn.normalize( schemaManager.getNormalizerMapping() ); |
| |
| List<Modification> mods = new ArrayList<Modification>(); |
| EntryAttribute attrib = new DefaultServerAttribute( SchemaConstants.OU_AT, schemaManager |
| .lookupAttributeTypeRegistry( SchemaConstants.OU_AT_OID ) ); |
| attrib.add( "Engineering" ); |
| |
| Modification add = new ServerModification( ModificationOperation.ADD_ATTRIBUTE, attrib ); |
| |
| mods.add( add ); |
| |
| store.modify( dn, mods ); |
| } |
| |
| |
| @Test |
| public void testRename() throws Exception |
| { |
| DN dn = new DN( "cn=Pivate Ryan,ou=Engineering,o=Good Times Co." ); |
| dn.normalize( schemaManager.getNormalizerMapping() ); |
| DefaultServerEntry entry = new DefaultServerEntry( schemaManager, dn ); |
| entry.add( "objectClass", "top", "person", "organizationalPerson" ); |
| entry.add( "ou", "Engineering" ); |
| entry.add( "cn", "Private Ryan" ); |
| entry.add( "entryCSN", new CsnFactory( 1 ).newInstance().toString() ); |
| entry.add( "entryUUID", UUID.randomUUID().toString() ); |
| |
| store.add( entry ); |
| |
| RDN rdn = new RDN( "sn=James" ); |
| |
| store.rename( dn, rdn, true ); |
| } |
| |
| |
| @Test |
| public void testRenameEscaped() throws Exception |
| { |
| DN dn = new DN( "cn=Pivate Ryan,ou=Engineering,o=Good Times Co." ); |
| dn.normalize( schemaManager.getNormalizerMapping() ); |
| DefaultServerEntry entry = new DefaultServerEntry( schemaManager, dn ); |
| entry.add( "objectClass", "top", "person", "organizationalPerson" ); |
| entry.add( "ou", "Engineering" ); |
| entry.add( "cn", "Private Ryan" ); |
| entry.add( "entryCSN", new CsnFactory( 1 ).newInstance().toString() ); |
| entry.add( "entryUUID", UUID.randomUUID().toString() ); |
| |
| store.add( entry ); |
| |
| RDN rdn = new RDN( "sn=Ja\\+es" ); |
| |
| store.rename( dn, rdn, true ); |
| |
| DN dn2 = new DN( "sn=Ja\\+es,ou=Engineering,o=Good Times Co." ); |
| dn2.normalize( schemaManager.getNormalizerMapping() ); |
| Long id = store.getEntryId( dn2.getNormName() ); |
| assertNotNull( id ); |
| ServerEntry entry2 = store.lookup( id ); |
| assertEquals( "Ja+es", entry2.get( "sn" ).getString() ); |
| } |
| |
| |
| @Test |
| public void testMove() throws Exception |
| { |
| DN childDn = new DN( "cn=Pivate Ryan,ou=Engineering,o=Good Times Co." ); |
| childDn.normalize( schemaManager.getNormalizerMapping() ); |
| DefaultServerEntry childEntry = new DefaultServerEntry( schemaManager, childDn ); |
| childEntry.add( "objectClass", "top", "person", "organizationalPerson" ); |
| childEntry.add( "ou", "Engineering" ); |
| childEntry.add( "cn", "Private Ryan" ); |
| childEntry.add( "entryCSN", new CsnFactory( 1 ).newInstance().toString() ); |
| childEntry.add( "entryUUID", UUID.randomUUID().toString() ); |
| |
| store.add( childEntry ); |
| |
| DN parentDn = new DN( "ou=Sales,o=Good Times Co." ); |
| parentDn.normalize( schemaManager.getNormalizerMapping() ); |
| |
| RDN rdn = new RDN( "cn=Ryan" ); |
| |
| store.move( childDn, parentDn, rdn, true ); |
| |
| // to drop the alias indices |
| childDn = new DN( "commonName=Jim Bean,ou=Apache,ou=Board of Directors,o=Good Times Co." ); |
| childDn.normalize( schemaManager.getNormalizerMapping() ); |
| |
| parentDn = new DN( "ou=Engineering,o=Good Times Co." ); |
| parentDn.normalize( schemaManager.getNormalizerMapping() ); |
| |
| assertEquals( 3, store.getSubAliasIndex().count() ); |
| |
| store.move( childDn, parentDn ); |
| |
| assertEquals( 4, store.getSubAliasIndex().count() ); |
| } |
| |
| |
| @Test |
| public void testModifyAdd() throws Exception |
| { |
| DN dn = new DN( "cn=JOhnny WAlkeR,ou=Sales,o=Good Times Co." ); |
| dn.normalize( schemaManager.getNormalizerMapping() ); |
| |
| List<Modification> mods = new ArrayList<Modification>(); |
| EntryAttribute attrib = new DefaultServerAttribute( SchemaConstants.SURNAME_AT, schemaManager |
| .lookupAttributeTypeRegistry( SchemaConstants.SURNAME_AT ) ); |
| |
| String attribVal = "Walker"; |
| attrib.add( attribVal ); |
| |
| Modification add = new ServerModification( ModificationOperation.ADD_ATTRIBUTE, attrib ); |
| mods.add( add ); |
| |
| ServerEntry lookedup = store.lookup( store.getEntryId( dn.getNormName() ) ); |
| |
| store.modify( dn, mods ); |
| assertTrue( lookedup.get( "sn" ).contains( attribVal ) ); |
| |
| // testing the store.modify( dn, mod, entry ) API |
| ServerEntry entry = new DefaultServerEntry( schemaManager, dn ); |
| attribVal = "+1974045779"; |
| entry.add( "telephoneNumber", attribVal ); |
| |
| store.modify( dn, ModificationOperation.ADD_ATTRIBUTE, entry ); |
| lookedup = store.lookup( store.getEntryId( dn.getNormName() ) ); |
| assertTrue( lookedup.get( "telephoneNumber" ).contains( attribVal ) ); |
| } |
| |
| |
| @Test |
| public void testModifyReplace() throws Exception |
| { |
| DN dn = new DN( "cn=JOhnny WAlkeR,ou=Sales,o=Good Times Co." ); |
| dn.normalize( schemaManager.getNormalizerMapping() ); |
| |
| List<Modification> mods = new ArrayList<Modification>(); |
| EntryAttribute attrib = new DefaultServerAttribute( SchemaConstants.SN_AT, schemaManager |
| .lookupAttributeTypeRegistry( SchemaConstants.SN_AT_OID ) ); |
| |
| String attribVal = "Johnny"; |
| attrib.add( attribVal ); |
| |
| Modification add = new ServerModification( ModificationOperation.REPLACE_ATTRIBUTE, attrib ); |
| mods.add( add ); |
| |
| ServerEntry lookedup = store.lookup( store.getEntryId( dn.getNormName() ) ); |
| |
| assertEquals( "WAlkeR", lookedup.get( "sn" ).get().getString() ); // before replacing |
| |
| store.modify( dn, mods ); |
| assertEquals( attribVal, lookedup.get( "sn" ).get().getString() ); |
| |
| // testing the store.modify( dn, mod, entry ) API |
| ServerEntry entry = new DefaultServerEntry( schemaManager, dn ); |
| attribVal = "JWalker"; |
| entry.add( "sn", attribVal ); |
| |
| store.modify( dn, ModificationOperation.REPLACE_ATTRIBUTE, entry ); |
| assertEquals( attribVal, lookedup.get( "sn" ).get().getString() ); |
| } |
| |
| |
| @Test |
| public void testModifyRemove() throws Exception |
| { |
| DN dn = new DN( "cn=JOhnny WAlkeR,ou=Sales,o=Good Times Co." ); |
| dn.normalize( schemaManager.getNormalizerMapping() ); |
| |
| List<Modification> mods = new ArrayList<Modification>(); |
| EntryAttribute attrib = new DefaultServerAttribute( SchemaConstants.SN_AT, schemaManager |
| .lookupAttributeTypeRegistry( SchemaConstants.SN_AT_OID ) ); |
| |
| Modification add = new ServerModification( ModificationOperation.REMOVE_ATTRIBUTE, attrib ); |
| mods.add( add ); |
| |
| ServerEntry lookedup = store.lookup( store.getEntryId( dn.getNormName() ) ); |
| |
| assertNotNull( lookedup.get( "sn" ).get() ); |
| |
| store.modify( dn, mods ); |
| assertNull( lookedup.get( "sn" ) ); |
| |
| // testing the store.modify( dn, mod, entry ) API |
| ServerEntry entry = new DefaultServerEntry( schemaManager, dn ); |
| |
| // add an entry for the sake of testing the remove operation |
| entry.add( "sn", "JWalker" ); |
| store.modify( dn, ModificationOperation.ADD_ATTRIBUTE, entry ); |
| assertNotNull( lookedup.get( "sn" ) ); |
| |
| store.modify( dn, ModificationOperation.REMOVE_ATTRIBUTE, entry ); |
| assertNull( lookedup.get( "sn" ) ); |
| } |
| |
| |
| @Test |
| public void testModifyReplaceNonExistingIndexAttribute() throws Exception |
| { |
| DN dn = new DN( "cn=Tim B,ou=Sales,o=Good Times Co." ); |
| dn.normalize( schemaManager.getNormalizerMapping() ); |
| DefaultServerEntry entry = new DefaultServerEntry( schemaManager, dn ); |
| entry.add( "objectClass", "top", "person", "organizationalPerson" ); |
| entry.add( "cn", "Tim B" ); |
| entry.add( "entryCSN", new CsnFactory( 1 ).newInstance().toString() ); |
| entry.add( "entryUUID", UUID.randomUUID().toString() ); |
| |
| store.add( entry ); |
| |
| List<Modification> mods = new ArrayList<Modification>(); |
| EntryAttribute attrib = new DefaultServerAttribute( SchemaConstants.OU_AT, schemaManager |
| .lookupAttributeTypeRegistry( SchemaConstants.OU_AT_OID ) ); |
| |
| String attribVal = "Marketing"; |
| attrib.add( attribVal ); |
| |
| Modification add = new ServerModification( ModificationOperation.REPLACE_ATTRIBUTE, attrib ); |
| mods.add( add ); |
| |
| ServerEntry lookedup = store.lookup( store.getEntryId( dn.getNormName() ) ); |
| |
| assertNull( lookedup.get( "ou" ) ); // before replacing |
| |
| store.modify( dn, mods ); |
| assertEquals( attribVal, lookedup.get( "ou" ).get().getString() ); |
| } |
| } |