mirror of https://github.com/OpenIdentityPlatform/OpenDJ.git

matthew_swift
08.28.2010 8cf467249a3cdfdab500aecd7b4dfaadd9f2c1bb
Fix issue 4446: allow empty attributes to be added to entries and also add support for empty attributes to LDIFWriter. This was preventing types-only from working in searches.
1 files added
3 files modified
185 ■■■■ changed files
sdk/src/org/opends/sdk/AbstractMapEntry.java 26 ●●●●● patch | view | raw | blame | history
sdk/src/org/opends/sdk/Entry.java 50 ●●●● patch | view | raw | blame | history
sdk/src/org/opends/sdk/ldif/LDIFEntryWriter.java 13 ●●●● patch | view | raw | blame | history
sdk/tests/unit-tests-testng/src/org/opends/sdk/ldif/LDIFEntryWriterTestCase.java 96 ●●●●● patch | view | raw | blame | history
sdk/src/org/opends/sdk/AbstractMapEntry.java
@@ -22,7 +22,7 @@
 * CDDL HEADER END
 *
 *
 *      Copyright 2009 Sun Microsystems, Inc.
 *      Copyright 2009-2010 Sun Microsystems, Inc.
 */
package org.opends.sdk;
@@ -74,22 +74,18 @@
  {
    Validator.ensureNotNull(attribute);
    if (!attribute.isEmpty())
    final AttributeDescription attributeDescription = attribute
        .getAttributeDescription();
    final Attribute oldAttribute = attributes.get(attributeDescription);
    if (oldAttribute != null)
    {
      final AttributeDescription attributeDescription = attribute
          .getAttributeDescription();
      final Attribute oldAttribute = attributes.get(attributeDescription);
      if (oldAttribute != null)
      {
        return oldAttribute.addAll(attribute, duplicateValues);
      }
      else
      {
        attributes.put(attributeDescription, attribute);
        return true;
      }
      return oldAttribute.addAll(attribute, duplicateValues);
    }
    return false;
    else
    {
      attributes.put(attributeDescription, attribute);
      return true;
    }
  }
sdk/src/org/opends/sdk/Entry.java
@@ -22,7 +22,7 @@
 * CDDL HEADER END
 *
 *
 *      Copyright 2009 Sun Microsystems, Inc.
 *      Copyright 2009-2010 Sun Microsystems, Inc.
 */
package org.opends.sdk;
@@ -62,11 +62,19 @@
{
  /**
   * Adds all of the attribute values contained in {@code attribute} to this
   * entry, merging with any existing attribute values (optional operation). If
   * {@code attribute} is empty then this entry is left unchanged.
   * Ensures that this entry contains the provided attribute and values
   * (optional operation). This method has the following semantics:
   * <ul>
   * <li>If this entry does not already contain an attribute with the same
   * attribute description, then this entry will be modified such that it
   * contains {@code attribute}, even if it is empty.
   * <li>If this entry already contains an attribute with the same attribute
   * description, then the attribute values contained in {@code attribute} will
   * be merged with the existing attribute values.
   * </ul>
   * <p>
   * <b>NOTE:</b> This method implements LDAP Modify add semantics.
   * <b>NOTE:</b> When {@code attribute} is non-empty, this method implements
   * LDAP Modify add semantics.
   *
   * @param attribute
   *          The attribute values to be added to this entry, merging with any
@@ -84,11 +92,19 @@
  /**
   * Adds all of the attribute values contained in {@code attribute} to this
   * entry, merging with any existing attribute values (optional operation). If
   * {@code attribute} is empty then this entry is left unchanged.
   * Ensures that this entry contains the provided attribute and values
   * (optional operation). This method has the following semantics:
   * <ul>
   * <li>If this entry does not already contain an attribute with the same
   * attribute description, then this entry will be modified such that it
   * contains {@code attribute}, even if it is empty.
   * <li>If this entry already contains an attribute with the same attribute
   * description, then the attribute values contained in {@code attribute} will
   * be merged with the existing attribute values.
   * </ul>
   * <p>
   * <b>NOTE:</b> This method implements LDAP Modify add semantics.
   * <b>NOTE:</b> When {@code attribute} is non-empty, this method implements
   * LDAP Modify add semantics.
   *
   * @param attribute
   *          The attribute values to be added to this entry, merging with any
@@ -110,9 +126,16 @@
  /**
   * Adds all of the attribute values contained in {@code values} to this entry,
   * merging with any existing attribute values (optional operation). If {@code
   * values} is {@code null} or empty then this entry is left unchanged.
   * Ensures that this entry contains the provided attribute and values
   * (optional operation). This method has the following semantics:
   * <ul>
   * <li>If this entry does not already contain an attribute with the same
   * attribute description, then this entry will be modified such that it
   * contains {@code attribute}, even if it is empty.
   * <li>If this entry already contains an attribute with the same attribute
   * description, then the attribute values contained in {@code attribute} will
   * be merged with the existing attribute values.
   * </ul>
   * <p>
   * The attribute description will be decoded using the schema associated with
   * this entry (usually the default schema).
@@ -120,7 +143,8 @@
   * Any attribute values which are not instances of {@code ByteString} will be
   * converted using the {@link ByteString#valueOf(Object)} method.
   * <p>
   * <b>NOTE:</b> This method implements LDAP Modify add semantics.
   * <b>NOTE:</b> When {@code attribute} is non-empty, this method implements
   * LDAP Modify add semantics.
   *
   * @param attributeDescription
   *          The name of the attribute whose values are to be added.
sdk/src/org/opends/sdk/ldif/LDIFEntryWriter.java
@@ -22,7 +22,7 @@
 * CDDL HEADER END
 *
 *
 *      Copyright 2009 Sun Microsystems, Inc.
 *      Copyright 2009-2010 Sun Microsystems, Inc.
 */
package org.opends.sdk.ldif;
@@ -341,9 +341,16 @@
      final String attributeDescription = attribute
          .getAttributeDescriptionAsString();
      for (final ByteString value : attribute)
      if (attribute.isEmpty())
      {
        writeKeyAndValue(attributeDescription, value);
        writeKeyAndValue(attributeDescription, ByteString.empty());
      }
      else
      {
        for (final ByteString value : attribute)
        {
          writeKeyAndValue(attributeDescription, value);
        }
      }
    }
sdk/tests/unit-tests-testng/src/org/opends/sdk/ldif/LDIFEntryWriterTestCase.java
New file
@@ -0,0 +1,96 @@
/*
 * CDDL HEADER START
 *
 * The contents of this file are subject to the terms of the
 * Common Development and Distribution License, Version 1.0 only
 * (the "License").  You may not use this file except in compliance
 * with the License.
 *
 * You can obtain a copy of the license at
 * trunk/opends/resource/legal-notices/OpenDS.LICENSE
 * or https://OpenDS.dev.java.net/OpenDS.LICENSE.
 * See the License for the specific language governing permissions
 * and limitations under the License.
 *
 * When distributing Covered Code, include this CDDL HEADER in each
 * file and include the License file at
 * trunk/opends/resource/legal-notices/OpenDS.LICENSE.  If applicable,
 * add the following below this CDDL HEADER, with the fields enclosed
 * by brackets "[]" replaced with your own identifying information:
 *      Portions Copyright [yyyy] [name of copyright owner]
 *
 * CDDL HEADER END
 *
 *
 *      Copyright 2009-2010 Sun Microsystems, Inc.
 */
package org.opends.sdk.ldif;
import java.util.ArrayList;
import java.util.List;
import org.opends.sdk.Entry;
import org.opends.sdk.LinkedHashMapEntry;
import org.testng.Assert;
import org.testng.annotations.Test;
/**
 * This class tests the LDIFEntryWriter functionality.
 */
public final class LDIFEntryWriterTestCase extends LDIFTestCase
{
  /**
   * Tests writeEntry method of LDIFEntryWriter class.See
   * https://opends.dev.java.net/issues/show_bug.cgi?id=4545 for more details.
   *
   * @throws Exception
   *           If the test failed unexpectedly.
   */
  @Test()
  public void testWriteEntry() throws Exception
  {
    final Entry entry = new LinkedHashMapEntry(
        "cn=John Doe,ou=people,dc=example,dc=com");
    entry.addAttribute("objectClass", "top", "person", "inetOrgPerson");
    entry.addAttribute("cn", "John Doe");
    entry.addAttribute("sn", "Doe");
    entry.addAttribute("givenName", "John");
    entry.addAttribute("description", "one two", "three four", "five six");
    entry.addAttribute("typeOnly");
    entry.addAttribute("localized;lang-fr", "\u00e7edilla");
    final List<String> actual = new ArrayList<String>();
    final LDIFEntryWriter writer = new LDIFEntryWriter(actual);
    writer.writeEntry(entry);
    writer.close();
    final String[] expected = new String[] {
        "dn: cn=John Doe,ou=people,dc=example,dc=com",
        "objectClass: top",
        "objectClass: person",
        "objectClass: inetOrgPerson",
        "cn: John Doe",
        "sn: Doe",
        "givenName: John",
        "description: one two",
        "description: three four",
        "description: five six",
        "typeOnly: ",
        "localized;lang-fr:: w6dlZGlsbGE=",
        "",
        };
    Assert.assertEquals(actual.size(), expected.length);
    for (int i = 0; i < expected.length; i++)
    {
      Assert.assertEquals(actual.get(i), expected[i], "LDIF output was "
          + actual);
    }
  }
}