From 0d247e6c0ecf6067d69dc063948bac0eebe37ff2 Mon Sep 17 00:00:00 2001
From: dugan <dugan@localhost>
Date: Thu, 05 Oct 2006 17:01:32 +0000
Subject: [PATCH] Fixes for issues 755 and 743

---
 opends/tests/unit-tests-testng/src/server/org/opends/server/backends/jeb/JebTestCase.java |   82 ++++++++++++++++++++++++++++++++++++++++
 1 files changed, 81 insertions(+), 1 deletions(-)

diff --git a/opends/tests/unit-tests-testng/src/server/org/opends/server/backends/jeb/JebTestCase.java b/opends/tests/unit-tests-testng/src/server/org/opends/server/backends/jeb/JebTestCase.java
index 7da0cca..7831bc0 100644
--- a/opends/tests/unit-tests-testng/src/server/org/opends/server/backends/jeb/JebTestCase.java
+++ b/opends/tests/unit-tests-testng/src/server/org/opends/server/backends/jeb/JebTestCase.java
@@ -26,7 +26,26 @@
  */
 package org.opends.server.backends.jeb;
 
+import static org.testng.Assert.assertEquals;
+
+import java.io.File;
+import java.util.ArrayList;
+import java.util.Random;
+import java.util.TreeMap;
+
+import org.opends.server.core.AddOperation;
+import org.opends.server.core.DeleteOperation;
+import org.opends.server.protocols.internal.InternalClientConnection;
+import org.opends.server.tools.makeldif.MakeLDIFInputStream;
+import org.opends.server.tools.makeldif.TemplateFile;
+import org.opends.server.types.DN;
+import org.opends.server.types.DNComparator;
+import org.opends.server.types.LDIFImportConfig;
+import org.opends.server.types.ResultCode;
 import org.opends.server.DirectoryServerTestCase;
+import org.opends.server.TestCaseUtils;
+import org.opends.server.types.Entry;
+import org.opends.server.util.LDIFReader;
 import org.testng.annotations.Test;
 
 /**
@@ -34,5 +53,66 @@
  */
 @Test(groups = { "precommit", "jeb" })
 public abstract class JebTestCase extends DirectoryServerTestCase {
-  // No implementation required.
+    private DNComparator comparator = new DNComparator();
+    private TreeMap<DN,Entry> entryTreeMap = new TreeMap<DN,Entry>(comparator);
+    int numEntries;
+    
+    /**
+     * This method takes an MakeLDIF template and a number of entries to create
+     * and adds the created entries into server.
+     * 
+     * @param template MakeLDIF template to use.
+     * @param numEntries Number of entries to create and add.
+     * @throws Exception if the entries cannot be created or if the add
+     *                                   fails.
+     */
+    protected void 
+    createLoadEntries(String[] template, int numEntries) throws Exception {
+        InternalClientConnection connection =
+            InternalClientConnection.getRootConnection();
+        String makeLDIFPath = 
+            System.getProperty(TestCaseUtils.PROPERTY_BUILD_ROOT) +
+        File.separator + "resource"+File.separator+"MakeLDIF";
+        TemplateFile templateFile = 
+            new TemplateFile(makeLDIFPath, new Random());
+        ArrayList<String> warnings = new ArrayList<String>();
+        templateFile.parse(template, warnings);
+        MakeLDIFInputStream ldifEntryStream = 
+            new MakeLDIFInputStream(templateFile);
+        LDIFReader reader = 
+            new LDIFReader(new LDIFImportConfig(ldifEntryStream));
+        for(int i =0; i<numEntries;i++) {
+            Entry entry = reader.readEntry(false);
+            entryTreeMap.put(entry.getDN(), entry);      
+            AddOperation addOperation =
+                connection.processAdd(entry.getDN(),
+                        entry.getObjectClasses(),
+                        entry.getUserAttributes(),
+                        entry.getOperationalAttributes());
+            assertEquals(addOperation.getResultCode(), ResultCode.SUCCESS,
+            "Add of this entry was not successful");
+        }
+        reader.close();
+        this.numEntries=numEntries;
+    }
+    
+    /**This method should be used to remove the entries created in the
+     * above loadEntries method.
+     * Note that it starts at the last key and works backwards so that the leaf
+     * entries are removed first before the top level nodes.
+     * 
+     * @throws Exception if the entries cannot be removed.
+     */
+    protected void
+    removeLoadedEntries() throws Exception {
+        InternalClientConnection connection =
+            InternalClientConnection.getRootConnection();
+        for(int j =0; j < numEntries; j++) {
+            DN entryDN = entryTreeMap.lastKey();
+            DeleteOperation deleteOperation =
+                connection.processDelete(entryDN);
+            entryTreeMap.remove(entryDN);
+            assertEquals(deleteOperation.getResultCode(), ResultCode.SUCCESS);
+        }
+    }
 }

--
Gitblit v1.10.0