You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@directory.apache.org by el...@apache.org on 2011/06/08 17:11:35 UTC

svn commit: r1133419 - in /directory/apacheds/trunk/server-integ/src/test/java/org/apache/directory/server/schema: ./ SchemaIT.java

Author: elecharny
Date: Wed Jun  8 15:11:35 2011
New Revision: 1133419

URL: http://svn.apache.org/viewvc?rev=1133419&view=rev
Log:
Added a test to check that DIRSERVER-1457 is now fixed : all is fine

Added:
    directory/apacheds/trunk/server-integ/src/test/java/org/apache/directory/server/schema/
    directory/apacheds/trunk/server-integ/src/test/java/org/apache/directory/server/schema/SchemaIT.java

Added: directory/apacheds/trunk/server-integ/src/test/java/org/apache/directory/server/schema/SchemaIT.java
URL: http://svn.apache.org/viewvc/directory/apacheds/trunk/server-integ/src/test/java/org/apache/directory/server/schema/SchemaIT.java?rev=1133419&view=auto
==============================================================================
--- directory/apacheds/trunk/server-integ/src/test/java/org/apache/directory/server/schema/SchemaIT.java (added)
+++ directory/apacheds/trunk/server-integ/src/test/java/org/apache/directory/server/schema/SchemaIT.java Wed Jun  8 15:11:35 2011
@@ -0,0 +1,343 @@
+    /*
+     *  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.schema;
+
+import static org.apache.directory.server.core.integ.IntegrationUtils.getRootContext;
+import static org.apache.directory.server.core.integ.IntegrationUtils.getSchemaContext;
+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.util.ArrayList;
+import java.util.Arrays;
+import java.util.List;
+
+import javax.naming.NamingEnumeration;
+import javax.naming.NamingException;
+import javax.naming.directory.Attribute;
+import javax.naming.directory.Attributes;
+import javax.naming.directory.BasicAttribute;
+import javax.naming.directory.BasicAttributes;
+import javax.naming.directory.DirContext;
+import javax.naming.directory.SearchControls;
+import javax.naming.directory.SearchResult;
+
+import org.apache.directory.server.core.annotations.CreateDS;
+import org.apache.directory.server.core.integ.AbstractLdapTestUnit;
+import org.apache.directory.server.core.integ.FrameworkRunner;
+import org.apache.directory.shared.ldap.model.name.Dn;
+import org.apache.directory.shared.ldap.model.schema.AttributeType;
+import org.apache.directory.shared.ldap.model.schema.ObjectClass;
+import org.apache.directory.shared.ldap.model.schema.parsers.AttributeTypeDescriptionSchemaParser;
+import org.apache.directory.shared.ldap.model.schema.parsers.ObjectClassDescriptionSchemaParser;
+import org.apache.directory.shared.ldap.util.JndiUtils;
+import org.junit.Test;
+import org.junit.runner.RunWith;
+
+/**
+ * An integration test class for testing the addition of schema elements
+ *
+ * @author <a href="mailto:dev@directory.apache.org">Apache Directory Project</a>
+ */
+@RunWith(FrameworkRunner.class)
+@CreateDS( name="SchemaIT-class" )
+public class SchemaIT extends AbstractLdapTestUnit
+{
+    private static final String SUBSCHEMA_SUBENTRY = "subschemaSubentry";
+    private static final AttributeTypeDescriptionSchemaParser ATTRIBUTE_TYPE_DESCRIPTION_SCHEMA_PARSER = new AttributeTypeDescriptionSchemaParser();
+    private static final ObjectClassDescriptionSchemaParser OBJECT_CLASS_DESCRIPTION_SCHEMA_PARSER = new ObjectClassDescriptionSchemaParser();
+
+
+    /**
+     * Tests to see if an attributeType is persisted when added, then server
+     * is shutdown, then restarted again.
+     *
+     * @throws Exception on error
+     */
+    @Test
+    public void testAddBinaryAttributeType() throws Exception
+    {
+        List<String> descriptions = new ArrayList<String>();
+
+        // -------------------------------------------------------------------
+        // test successful add with everything
+        // -------------------------------------------------------------------
+
+        descriptions.add(
+            "( 1.3.6.1.4.1.65536.0.4.3.2.1" +
+            " NAME 'templateData'" +
+            " DESC 'template data'" +
+            " SYNTAX 1.3.6.1.4.1.1466.115.121.1.5" +
+            " SINGLE-VALUE" +
+            " X-SCHEMA 'other' )" );
+
+        modify( DirContext.ADD_ATTRIBUTE, descriptions, "attributeTypes" );
+
+        descriptions.clear();
+        descriptions.add(
+            "( 1.3.6.1.4.1.65536.0.4.3.2.2 " +
+            " NAME 'templateObject' " +
+            " DESC 'test OC' " +
+            " SUP top " +
+            " STRUCTURAL " +
+            " MUST ( templateData $ cn ) " +
+            " X-SCHEMA 'other' )");
+
+         modify( DirContext.ADD_ATTRIBUTE, descriptions, "objectClasses" );
+
+        checkAttributeTypePresent( "1.3.6.1.4.1.65536.0.4.3.2.1", "other", true );
+        checkObjectClassPresent( "1.3.6.1.4.1.65536.0.4.3.2.2", "other", true );
+
+        // sync operation happens anyway on shutdowns but just to make sure we can do it again
+        getService().sync();
+
+        getService().shutdown();
+        getService().startup();
+
+        checkAttributeTypePresent( "1.3.6.1.4.1.65536.0.4.3.2.1", "other", true );
+        checkObjectClassPresent( "1.3.6.1.4.1.65536.0.4.3.2.2", "other", true );
+
+        Attributes attrs = new BasicAttributes();
+        BasicAttribute ocattr = new BasicAttribute( "objectclass" );
+        ocattr.add( "top" );
+        ocattr.add( "templateObject" );
+        attrs.put( ocattr );
+        byte[] templateData = new byte[4096];
+        attrs.put( "templateData", templateData );
+        attrs.put( "cn", "atemplate" );
+        getRootContext( getService() ).bind( "cn=atemplate,ou=system", null, attrs );
+        
+        Attributes data = getRootContext( getService() ).getAttributes( "cn=atemplate,ou=system", new String[]{"templateData", "cn"} );
+        
+        assertTrue( Arrays.equals( templateData, (byte[])data.get( "templateData" ).get() ) );
+    }
+
+
+    // -----------------------------------------------------------------------
+    // Private Utility Methods
+    // -----------------------------------------------------------------------
+
+    private void modify( int op, List<String> descriptions, String opAttr ) throws Exception
+    {
+        Dn dn = new Dn( getSubschemaSubentryDN() );
+        Attribute attr = new BasicAttribute( opAttr );
+
+        for ( String description : descriptions )
+        {
+            attr.add( description );
+        }
+
+        Attributes mods = new BasicAttributes( true );
+        mods.put( attr );
+
+        getRootContext( getService() ).modifyAttributes( JndiUtils.toName( dn ), op, mods );
+    }
+
+
+    /**
+     * Get's the subschemaSubentry attribute value from the rootDSE.
+     *
+     * @return the subschemaSubentry distinguished name
+     * @throws NamingException if there are problems accessing the RootDSE
+     */
+    private String getSubschemaSubentryDN() throws Exception
+    {
+        SearchControls controls = new SearchControls();
+        controls.setSearchScope( SearchControls.OBJECT_SCOPE );
+        controls.setReturningAttributes( new String[]
+            { SUBSCHEMA_SUBENTRY } );
+
+        NamingEnumeration<SearchResult> results = getRootContext( getService() ).search( "", "(objectClass=*)", controls );
+        SearchResult result = results.next();
+        results.close();
+        Attribute subschemaSubentry = result.getAttributes().get( SUBSCHEMA_SUBENTRY );
+        return ( String ) subschemaSubentry.get();
+    }
+
+
+    /**
+     * Gets the subschemaSubentry attributes for the global schema.
+     *
+     * @return all operational attributes of the subschemaSubentry
+     * @throws NamingException if there are problems accessing this entry
+     */
+    private Attributes getSubschemaSubentryAttributes() throws Exception
+    {
+        SearchControls controls = new SearchControls();
+        controls.setSearchScope( SearchControls.OBJECT_SCOPE );
+        controls.setReturningAttributes( new String[]
+            { "+", "*" } );
+
+        NamingEnumeration<SearchResult> results = getRootContext( getService() ).search( getSubschemaSubentryDN(),
+            "(objectClass=*)", controls );
+        SearchResult result = results.next();
+        results.close();
+        return result.getAttributes();
+    }
+
+
+    private void checkAttributeTypePresent( String oid, String schemaName, boolean isPresent ) throws Exception
+    {
+        // -------------------------------------------------------------------
+        // check first to see if it is present in the subschemaSubentry
+        // -------------------------------------------------------------------
+
+        Attributes attrs = getSubschemaSubentryAttributes();
+        Attribute attrTypes = attrs.get( "attributeTypes" );
+        AttributeType attributeType = null;
+
+        for ( int i = 0; i < attrTypes.size(); i++ )
+        {
+            String desc = ( String ) attrTypes.get( i );
+
+            if ( desc.indexOf( oid ) != -1 )
+            {
+                attributeType = ATTRIBUTE_TYPE_DESCRIPTION_SCHEMA_PARSER
+                    .parseAttributeTypeDescription( desc );
+                break;
+            }
+        }
+
+        if ( isPresent )
+        {
+            assertNotNull( attributeType );
+            assertEquals( oid, attributeType.getOid() );
+        }
+        else
+        {
+            assertNull( attributeType );
+        }
+
+        // -------------------------------------------------------------------
+        // check next to see if it is present in the schema partition
+        // -------------------------------------------------------------------
+
+        attrs = null;
+
+        if ( isPresent )
+        {
+            attrs = getSchemaContext( getService() ).getAttributes( "m-oid=" + oid + ",ou=attributeTypes,cn=" + schemaName );
+            assertNotNull( attrs );
+        }
+        else
+        {
+            //noinspection EmptyCatchBlock
+            try
+            {
+                attrs = getSchemaContext( getService() ).getAttributes(
+                    "m-oid=" + oid + ",ou=attributeTypes,cn=" + schemaName );
+                fail( "should never get here" );
+            }
+            catch ( NamingException e )
+            {
+            }
+            assertNull( attrs );
+        }
+
+        // -------------------------------------------------------------------
+        // check to see if it is present in the attributeTypeRegistry
+        // -------------------------------------------------------------------
+
+        if ( isPresent )
+        {
+            assertTrue( getService().getSchemaManager().getAttributeTypeRegistry().contains( oid ) );
+        }
+        else
+        {
+            assertFalse( getService().getSchemaManager().getAttributeTypeRegistry().contains( oid ) );
+        }
+    }
+
+
+    private void checkObjectClassPresent( String oid, String schemaName, boolean isPresent ) throws Exception
+    {
+        // -------------------------------------------------------------------
+        // check first to see if it is present in the subschemaSubentry
+        // -------------------------------------------------------------------
+
+        Attributes attrs = getSubschemaSubentryAttributes();
+        Attribute attrTypes = attrs.get( "objectClasses" );
+        ObjectClass objectClass = null;
+
+        for ( int i = 0; i < attrTypes.size(); i++ )
+        {
+            String desc = ( String ) attrTypes.get( i );
+
+            if ( desc.indexOf( oid ) != -1 )
+            {
+                objectClass = OBJECT_CLASS_DESCRIPTION_SCHEMA_PARSER
+                    .parseObjectClassDescription( desc );
+                break;
+            }
+        }
+
+        if ( isPresent )
+        {
+            assertNotNull( objectClass );
+            assertEquals( oid, objectClass.getOid() );
+        }
+        else
+        {
+            assertNull( objectClass );
+        }
+
+        // -------------------------------------------------------------------
+        // check next to see if it is present in the schema partition
+        // -------------------------------------------------------------------
+
+        attrs = null;
+
+        if ( isPresent )
+        {
+            attrs = getSchemaContext( getService() ).getAttributes( "m-oid=" + oid + ",ou=objectClasses,cn=" + schemaName );
+            assertNotNull( attrs );
+        }
+        else
+        {
+            //noinspection EmptyCatchBlock
+            try
+            {
+                attrs = getSchemaContext( getService() ).getAttributes(
+                    "m-oid=" + oid + ",ou=objectClasses,cn=" + schemaName );
+                fail( "should never get here" );
+            }
+            catch ( NamingException e )
+            {
+            }
+            assertNull( attrs );
+        }
+
+        // -------------------------------------------------------------------
+        // check to see if it is present in the objectClassRegistry
+        // -------------------------------------------------------------------
+
+        if ( isPresent )
+        {
+            assertTrue( getService().getSchemaManager().getObjectClassRegistry().contains( oid ) );
+        }
+        else
+        {
+            assertFalse( getService().getSchemaManager().getObjectClassRegistry().contains( oid ) );
+        }
+    }
+}