Remove tests for Samba 3 EJS code.
authorJelmer Vernooij <jelmer@samba.org>
Mon, 11 Feb 2008 12:38:07 +0000 (13:38 +0100)
committerJelmer Vernooij <jelmer@samba.org>
Mon, 11 Feb 2008 12:38:07 +0000 (13:38 +0100)
(This used to be commit 7aff2ddd8ca1ff68fc704fdb139d81d6daa51115)

source4/selftest/samba4_tests.sh
testdata/samba3/verify [deleted file]
testprogs/ejs/samba3sam.js [deleted file]

index c2ce9dc6f1d8185b90bc141fee77e3d757fdb73c..b1d85219fccfc496ead0d13fce43cc537880c002 100755 (executable)
@@ -43,7 +43,7 @@ plantest() {
 $incdir/../bin/smbtorture -V
 
 samba4srcdir=$incdir/..
-samba4bindir=$samba4srcdir/bin
+samba4biir=$samba4srcdir/bin
 SCRIPTDIR=$samba4srcdir/../testprogs/ejs
 smb4torture="$samba4bindir/smbtorture $TORTURE_OPTIONS"
 
@@ -262,9 +262,6 @@ done
 
 DATADIR=$samba4srcdir/../testdata
 
-plantest "parse samba3" none $samba4bindir/smbscript $DATADIR/samba3/verify $CONFIGURATION $DATADIR/samba3
-plantest "js.samba3sam" none $SCRIPTDIR/samba3sam.js $CONFIGURATION `pwd` $DATADIR/samba3/
-
 # Domain Member Tests
 
 plantest "RPC-ECHO against member server with local creds" member $VALGRIND $smb4torture ncacn_np:"\$NETBIOSNAME" -U"\$NETBIOSNAME/\$USERNAME"%"\$PASSWORD" RPC-ECHO "$*"
diff --git a/testdata/samba3/verify b/testdata/samba3/verify
deleted file mode 100755 (executable)
index ca495b1..0000000
+++ /dev/null
@@ -1,59 +0,0 @@
-#!/usr/bin/env smbscript
-/* Verifies that the data present in this directory
- Can be read correctly by Samba4. Do not update 
- without changing the corresponding TDB file!
- Written by Jelmer Vernooij, 2005.
- */
-
-var sys;
-var options = GetOptions(ARGV, "POPT_AUTOHELP", "POPT_COMMON_SAMBA");
-if (options == undefined) {
-       println("Failed to parse options");
-       return -1;
-}
-
-libinclude("base.js");
-
-var path = substr(ARGV[0], 0, -strlen("verify"));
-printf("Reading from %s\n", path);
-
-var s = samba3_read(path, path+"smb.conf");
-assert(s != undefined);
-
-// smb.conf checks
-assert(s.configuration.get("passdb backend") != undefined);
-
-var data = s.configuration.data();
-assert(data != undefined);
-var global = data["global"];
-assert(global != undefined);
-assert(global["passdb backend"] == s.configuration.get("passdb backend"));
-assert(global["passdb backend"] != undefined);
-
-println("smb.conf ok");
-
-assert(s.winsentries.length == 22);
-assert(s.samaccounts.length == 3);
-assert(s.shares.length == 0);
-assert(s.registry.keys.length == 28);
-assert(s.groupmappings.length == 13);
-assert(s.aliases.length == 0);
-assert(s.idmapdb.mappings.length == 4);
-
-println("database entry count correct");
-
-// account policies
-assert(s.policy.min_password_length == 5);
-assert(s.policy.minimum_password_age == 0);
-assert(s.policy.maximum_password_age == 999999999);
-assert(s.policy.refuse_machine_password_change == 0);
-assert(s.policy.reset_count_minutes == 0);
-assert(s.policy.disconnect_time == -1);
-assert(s.policy.user_must_logon_to_change_password == 0);
-assert(s.policy.password_history == 0);
-assert(s.policy.lockout_duration == 0);
-assert(s.policy.bad_lockout_minutes == 0);
-
-println("account policies ok");
-
-exit(0);
diff --git a/testprogs/ejs/samba3sam.js b/testprogs/ejs/samba3sam.js
deleted file mode 100755 (executable)
index e5639b8..0000000
+++ /dev/null
@@ -1,1255 +0,0 @@
-#!/usr/bin/env smbscript
-/*
-  (C) Jelmer Vernooij <jelmer@samba.org> 2005
-  (C) Martin Kuehl <mkhl@samba.org> 2006
-  Published under the GNU GPL
-  Sponsored by Google Summer of Code
- */
-
-var sys;
-var options = GetOptions(ARGV, "POPT_AUTOHELP", "POPT_COMMON_SAMBA");
-if (options == undefined) {
-       println("Failed to parse options");
-       return -1;
-}
-
-libinclude("base.js");
-
-if (options.ARGV.length != 2) {
-       println("Usage: samba3sam.js <TESTDIR> <DATADIR>");
-       return -1;
-}
-
-var prefix = options.ARGV[0];
-var datadir = options.ARGV[1];
-
-function setup_data(obj, ldif)
-{
-       assert(ldif != undefined);
-       ldif = substitute_var(ldif, obj);
-       assert(ldif != undefined);
-       var ok = obj.db.add(ldif);
-       assert(ok.error == 0);
-}
-
-function setup_modules(ldb, s3, s4, ldif)
-{
-       assert(ldif != undefined);
-       ldif = substitute_var(ldif, s4);
-       assert(ldif != undefined);
-       var ok = ldb.add(ldif);
-       assert(ok.error == 0);
-
-       var ldif = "
-dn: @MAP=samba3sam
-@FROM: " + s4.BASEDN + "
-@TO: sambaDomainName=TESTS," + s3.BASEDN + "
-
-dn: @MODULES
-@LIST: rootdse,paged_results,server_sort,extended_dn,asq,samldb,password_hash,operational,objectguid,rdn_name,samba3sam,partition
-
-dn: @PARTITION
-partition: " + s4.BASEDN + ":" + s4.url + "
-partition: " + s3.BASEDN + ":" + s3.url + "
-replicateEntries: @SUBCLASSES
-replicateEntries: @ATTRIBUTES
-replicateEntries: @INDEXLIST
-";
-       var ok = ldb.add(ldif);
-       assert(ok.error == 0);
-}
-
-function test_s3sam_search(ldb)
-{
-       println("Looking up by non-mapped attribute");
-       var msg = ldb.search("(cn=Administrator)");
-       assert(msg.error == 0);
-       assert(msg.msgs.length == 1);
-       assert(msg.msgs[0].cn == "Administrator");
-
-       println("Looking up by mapped attribute");
-       var msg = ldb.search("(name=Backup Operators)");
-       assert(msg.error == 0);
-       assert(msg.msgs.length == 1);
-       assert(msg.msgs[0].name == "Backup Operators");
-
-       println("Looking up by old name of renamed attribute");
-       var msg = ldb.search("(displayName=Backup Operators)");
-       assert(msg.msgs.length == 0);
-
-       println("Looking up mapped entry containing SID");
-       var msg = ldb.search("(cn=Replicator)");
-       assert(msg.error == 0);
-       assert(msg.msgs.length == 1);
-       println(msg.msgs[0].dn);
-       assert(msg.msgs[0].dn == "cn=Replicator,ou=Groups,dc=vernstok,dc=nl");
-       assert(msg.msgs[0].objectSid == "S-1-5-21-4231626423-2410014848-2360679739-552");
-
-       println("Checking mapping of objectClass");
-       var oc = msg.msgs[0].objectClass;
-       assert(oc != undefined);
-       for (var i in oc) {
-               assert(oc[i] == "posixGroup" || oc[i] == "group");
-       }
-
-       println("Looking up by objectClass");
-       var msg = ldb.search("(|(objectClass=user)(cn=Administrator))");
-       assert(msg.error == 0);
-       assert(msg.msgs.length == 2);
-       for (var i = 0; i < msg.msgs.length; i++) {
-               assert((msg.msgs[i].dn == "unixName=Administrator,ou=Users,dc=vernstok,dc=nl") ||
-                      (msg.msgs[i].dn == "unixName=nobody,ou=Users,dc=vernstok,dc=nl"));
-       }
-}
-
-function test_s3sam_modify(ldb, s3)
-{
-       var msg, ok;
-       println("Adding a record that will be fallbacked");
-       ok = ldb.add("
-dn: cn=Foo
-foo: bar
-blah: Blie
-cn: Foo
-showInAdvancedViewOnly: TRUE
-");
-       if (ok.error != 0) {
-               println(ok.errstr);
-               assert(ok.error == 0);
-       }
-
-       println("Checking for existence of record (local)");
-       /* TODO: This record must be searched in the local database, which is currently only supported for base searches
-        * msg = ldb.search("(cn=Foo)", new Array('foo','blah','cn','showInAdvancedViewOnly'));
-        * TODO: Actually, this version should work as well but doesn't...
-        * 
-        */
-       var attrs =  new Array('foo','blah','cn','showInAdvancedViewOnly');
-       msg = ldb.search("(cn=Foo)", "cn=Foo", ldb.LDB_SCOPE_BASE, attrs);
-       assert(msg.error == 0);
-       assert(msg.msgs.length == 1);
-       assert(msg.msgs[0].showInAdvancedViewOnly == "TRUE");
-       assert(msg.msgs[0].foo == "bar");
-       assert(msg.msgs[0].blah == "Blie");
-
-       println("Adding record that will be mapped");
-       ok = ldb.add("
-dn: cn=Niemand,cn=Users,dc=vernstok,dc=nl
-objectClass: user
-unixName: bin
-sambaUnicodePwd: geheim
-cn: Niemand
-");
-       if (ok.error != 0) {
-               println(ok.errstr);
-               assert(ok.error == 0);
-       }
-       assert(ok.error == 0);
-
-       println("Checking for existence of record (remote)");
-       msg = ldb.search("(unixName=bin)", new Array('unixName','cn','dn', 'sambaUnicodePwd'));
-       assert(msg.error == 0);
-       assert(msg.msgs.length == 1);
-       assert(msg.msgs[0].cn == "Niemand"); 
-       assert(msg.msgs[0].sambaUnicodePwd == "geheim");
-
-       println("Checking for existence of record (local && remote)");
-       msg = ldb.search("(&(unixName=bin)(sambaUnicodePwd=geheim))", new Array('unixName','cn','dn', 'sambaUnicodePwd'));
-       assert(msg.error == 0);
-       assert(msg.msgs.length == 1);           // TODO: should check with more records
-       assert(msg.msgs[0].cn == "Niemand");
-       assert(msg.msgs[0].unixName == "bin");
-       assert(msg.msgs[0].sambaUnicodePwd == "geheim");
-
-       println("Checking for existence of record (local || remote)");
-       msg = ldb.search("(|(unixName=bin)(sambaUnicodePwd=geheim))", new Array('unixName','cn','dn', 'sambaUnicodePwd'));
-       println("got " + msg.msgs.length + " replies");
-       assert(msg.error == 0);
-       assert(msg.msgs.length == 1);           // TODO: should check with more records
-       assert(msg.msgs[0].cn == "Niemand");
-       assert(msg.msgs[0].unixName == "bin" || msg.msgs[0].sambaUnicodePwd == "geheim");
-
-       println("Checking for data in destination database");
-       msg = s3.db.search("(cn=Niemand)");
-       assert(msg.error == 0);
-       assert(msg.msgs.length >= 1);
-       assert(msg.msgs[0].sambaSID == "S-1-5-21-4231626423-2410014848-2360679739-2001");
-       assert(msg.msgs[0].displayName == "Niemand");
-
-       println("Adding attribute...");
-       ok = ldb.modify("
-dn: cn=Niemand,cn=Users,dc=vernstok,dc=nl
-changetype: modify
-add: description
-description: Blah
-");
-       if (ok.error != 0) {
-               println(ok.errstr);
-               assert(ok.error == 0);
-       }
-       assert(ok.error == 0);
-
-       println("Checking whether changes are still there...");
-       msg = ldb.search("(cn=Niemand)");
-       assert(msg.error == 0);
-       assert(msg.msgs.length >= 1);
-       assert(msg.msgs[0].cn == "Niemand");
-       assert(msg.msgs[0].description == "Blah");
-
-       println("Modifying attribute...");
-       ok = ldb.modify("
-dn: cn=Niemand,cn=Users,dc=vernstok,dc=nl
-changetype: modify
-replace: description
-description: Blie
-");
-               if (ok.error != 0) {
-                       println(ok.errstr);
-                       assert(ok.error == 0);
-               }
-       assert(ok.error == 0);
-
-       println("Checking whether changes are still there...");
-       msg = ldb.search("(cn=Niemand)");
-       assert(msg.error == 0);
-       assert(msg.msgs.length >= 1);
-       assert(msg.msgs[0].description == "Blie");
-
-       println("Deleting attribute...");
-       ok = ldb.modify("
-dn: cn=Niemand,cn=Users,dc=vernstok,dc=nl
-changetype: modify
-delete: description
-");
-       if (ok.error != 0) {
-               println(ok.errstr);
-               assert(ok.error == 0);
-       }
-       assert(ok.error == 0);
-
-       println("Checking whether changes are no longer there...");
-       msg = ldb.search("(cn=Niemand)");
-       assert(msg.error == 0);
-       assert(msg.msgs.length >= 1);
-       assert(msg.msgs[0].description == undefined);
-
-       println("Renaming record...");
-       ok = ldb.rename("cn=Niemand,cn=Users,dc=vernstok,dc=nl", "cn=Niemand2,cn=Users,dc=vernstok,dc=nl");
-       assert(ok.error == 0);
-
-       println("Checking whether DN has changed...");
-       msg = ldb.search("(cn=Niemand2)");
-       assert(msg.error == 0);
-       assert(msg.msgs.length == 1);
-       assert(msg.msgs[0].dn == "cn=Niemand2,cn=Users,dc=vernstok,dc=nl");
-
-       println("Deleting record...");
-       ok = ldb.del("cn=Niemand2,cn=Users,dc=vernstok,dc=nl");
-       if (ok.error != 0) {
-               println(ok.errstr);
-               assert(ok.error == 0);
-       }
-
-       println("Checking whether record is gone...");
-       msg = ldb.search("(cn=Niemand2)");
-       assert(msg.error == 0);
-       assert(msg.msgs.length == 0);
-}
-
-function test_map_search(ldb, s3, s4)
-{
-       println("Running search tests on mapped data");
-       var res;
-       var dn;
-       var attrs;
-
-
-       var ldif = "
-dn: " + "sambaDomainName=TESTS," + s3.BASEDN + "
-objectclass: sambaDomain
-objectclass: top
-sambaSID: S-1-5-21-4231626423-2410014848-2360679739
-sambaNextRid: 2000
-sambaDomainName: TESTS"
-       ldif = substitute_var(ldif, s3);
-       assert(ldif != undefined);
-       var ok = s3.db.add(ldif);
-       assert(ok.error == 0);
-
-       printf("Add a set of split records");
-       var ldif = "
-dn: " + s4.dn("cn=X") + "
-objectClass: user
-cn: X
-codePage: x
-revision: x
-dnsHostName: x
-nextRid: y
-lastLogon: x
-description: x
-objectSid: S-1-5-21-4231626423-2410014848-2360679739-552
-primaryGroupID: 1-5-21-4231626423-2410014848-2360679739-512
-
-dn: " + s4.dn("cn=Y") + "
-objectClass: top
-cn: Y
-codePage: x
-revision: x
-dnsHostName: y
-nextRid: y
-lastLogon: y
-description: x
-
-dn: " + s4.dn("cn=Z") + "
-objectClass: top
-cn: Z
-codePage: x
-revision: y
-dnsHostName: z
-nextRid: y
-lastLogon: z
-description: y
-";
-
-       ldif = substitute_var(ldif, s4);
-       assert(ldif != undefined);
-       var ok = ldb.add(ldif);
-       if (ok.error != 0) {
-               println(ok.errstr);
-               assert(ok.error == 0);
-       }
-
-       println("Add a set of remote records");
-
-       var ldif = "
-dn: " + s3.dn("cn=A") + "
-objectClass: posixAccount
-cn: A
-sambaNextRid: x
-sambaBadPasswordCount: x
-sambaLogonTime: x
-description: x
-sambaSID: S-1-5-21-4231626423-2410014848-2360679739-552
-sambaPrimaryGroupSID: S-1-5-21-4231626423-2410014848-2360679739-512
-
-dn: " + s3.dn("cn=B") + "
-objectClass: top
-cn:B
-sambaNextRid: x
-sambaBadPasswordCount: x
-sambaLogonTime: y
-description: x
-
-dn: " + s3.dn("cn=C") + "
-objectClass: top
-cn: C
-sambaNextRid: x
-sambaBadPasswordCount: y
-sambaLogonTime: z
-description: y
-";
-       ldif = substitute_var(ldif, s3);
-       assert(ldif != undefined);
-       var ok = s3.db.add(ldif);
-       assert(ok.error == 0);
-
-       println("Testing search by DN");
-
-       /* Search remote record by local DN */
-       dn = s4.dn("cn=A");
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].dnsHostName == undefined);
-       assert(res.msgs[0].lastLogon == "x");
-
-       /* Search remote record by remote DN */
-       dn = s3.dn("cn=A");
-       attrs = new Array("dnsHostName", "lastLogon", "sambaLogonTime");
-       res = s3.db.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].dnsHostName == undefined);
-       assert(res.msgs[0].lastLogon == undefined);
-       assert(res.msgs[0].sambaLogonTime == "x");
-
-       /* Search split record by local DN */
-       dn = s4.dn("cn=X");
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].dnsHostName == "x");
-       assert(res.msgs[0].lastLogon == "x");
-
-       /* Search split record by remote DN */
-       dn = s3.dn("cn=X");
-       attrs = new Array("dnsHostName", "lastLogon", "sambaLogonTime");
-       res = s3.db.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].dnsHostName == undefined);
-       assert(res.msgs[0].lastLogon == undefined);
-       assert(res.msgs[0].sambaLogonTime == "x");
-
-       println("Testing search by attribute");
-
-       /* Search by ignored attribute */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(revision=x)", NULL, ldb. SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 2);
-       assert(res.msgs[0].dn == s4.dn("cn=Y"));
-       assert(res.msgs[0].dnsHostName == "y");
-       assert(res.msgs[0].lastLogon == "y");
-       assert(res.msgs[1].dn == s4.dn("cn=X"));
-       assert(res.msgs[1].dnsHostName == "x");
-       assert(res.msgs[1].lastLogon == "x");
-
-       /* Search by kept attribute */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(description=y)", NULL, ldb. SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 2);
-       assert(res.msgs[0].dn == s4.dn("cn=Z"));
-       assert(res.msgs[0].dnsHostName == "z");
-       assert(res.msgs[0].lastLogon == "z");
-       assert(res.msgs[1].dn == s4.dn("cn=C"));
-       assert(res.msgs[1].dnsHostName == undefined);
-       assert(res.msgs[1].lastLogon == "z");
-
-       /* Search by renamed attribute */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(badPwdCount=x)", NULL, ldb. SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 2);
-       assert(res.msgs[0].dn == s4.dn("cn=B"));
-       assert(res.msgs[0].dnsHostName == undefined);
-       assert(res.msgs[0].lastLogon == "y");
-       assert(res.msgs[1].dn == s4.dn("cn=A"));
-       assert(res.msgs[1].dnsHostName == undefined);
-       assert(res.msgs[1].lastLogon == "x");
-
-       /* Search by converted attribute */
-       attrs = new Array("dnsHostName", "lastLogon", "objectSid");
-       /* TODO:
-          Using the SID directly in the parse tree leads to conversion
-          errors, letting the search fail with no results.
-       res = ldb.search("(objectSid=S-1-5-21-4231626423-2410014848-2360679739-552)", NULL, ldb. SCOPE_DEFAULT, attrs);
-       */
-       res = ldb.search("(objectSid=*)", NULL, ldb. SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 3);
-       assert(res.msgs[0].dn == s4.dn("cn=X"));
-       assert(res.msgs[0].dnsHostName == "x");
-       assert(res.msgs[0].lastLogon == "x");
-       assert(res.msgs[0].objectSid == "S-1-5-21-4231626423-2410014848-2360679739-552");
-       assert(res.msgs[1].dn == s4.dn("cn=A"));
-       assert(res.msgs[1].dnsHostName == undefined);
-       assert(res.msgs[1].lastLogon == "x");
-       assert(res.msgs[1].objectSid == "S-1-5-21-4231626423-2410014848-2360679739-552");
-
-       /* Search by generated attribute */
-       /* In most cases, this even works when the mapping is missing
-        * a `convert_operator' by enumerating the remote db. */
-       attrs = new Array("dnsHostName", "lastLogon", "primaryGroupID");
-       res = ldb.search("(primaryGroupID=512)", NULL, ldb. SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == s4.dn("cn=A"));
-       assert(res.msgs[0].dnsHostName == undefined);
-       assert(res.msgs[0].lastLogon == "x");
-       assert(res.msgs[0].primaryGroupID == "512");
-
-       /* TODO: There should actually be two results, A and X.  The
-        * primaryGroupID of X seems to get corrupted somewhere, and the
-        * objectSid isn't available during the generation of remote (!) data,
-        * which can be observed with the following search.  Also note that Xs
-        * objectSid seems to be fine in the previous search for objectSid... */
-       /*
-       res = ldb.search("(primaryGroupID=*)", NULL, ldb. SCOPE_DEFAULT, attrs);
-       println(res.msgs.length + " results found");
-       for (i=0;i<res.msgs.length;i++) {
-               for (obj in res.msgs[i]) {
-                       println(obj + ": " + res.msgs[i][obj]);
-               }
-               println("---");
-       }
-       */
-
-       /* Search by remote name of renamed attribute */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(sambaBadPasswordCount=*)", "", ldb. SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 0);
-
-       /* Search by objectClass */
-       attrs = new Array("dnsHostName", "lastLogon", "objectClass");
-       res = ldb.search("(objectClass=user)", NULL, ldb. SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 2);
-       assert(res.msgs[0].dn == s4.dn("cn=X"));
-       assert(res.msgs[0].dnsHostName == "x");
-       assert(res.msgs[0].lastLogon == "x");
-       assert(res.msgs[0].objectClass != undefined);
-       assert(res.msgs[0].objectClass[0] == "user"); 
-       assert(res.msgs[1].dn == s4.dn("cn=A"));
-       assert(res.msgs[1].dnsHostName == undefined);
-       assert(res.msgs[1].lastLogon == "x");
-       assert(res.msgs[1].objectClass != undefined);
-       assert(res.msgs[1].objectClass[0] == "user");
-
-       /* Prove that the objectClass is actually used for the search */
-       res = ldb.search("(|(objectClass=user)(badPwdCount=x))", NULL, ldb. SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 3);
-       assert(res.msgs[0].dn == s4.dn("cn=B"));
-       assert(res.msgs[0].dnsHostName == undefined);
-       assert(res.msgs[0].lastLogon == "y");
-       assert(res.msgs[0].objectClass != undefined);
-       for (i=0;i<res.msgs[0].objectClass.length;i++) {
-               assert(res.msgs[0].objectClass[i] != "user");
-       }
-       assert(res.msgs[1].dn == s4.dn("cn=X"));
-       assert(res.msgs[1].dnsHostName == "x");
-       assert(res.msgs[1].lastLogon == "x");
-       assert(res.msgs[1].objectClass != undefined);
-       assert(res.msgs[1].objectClass[0] == "user");
-       assert(res.msgs[2].dn == s4.dn("cn=A"));
-       assert(res.msgs[2].dnsHostName == undefined);
-       assert(res.msgs[2].lastLogon == "x");
-       assert(res.msgs[2].objectClass != undefined);
-       assert(res.msgs[2].objectClass[0] == "user");
-
-       println("Testing search by parse tree");
-
-       /* Search by conjunction of local attributes */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(&(codePage=x)(revision=x))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 2);
-       assert(res.msgs[0].dn == s4.dn("cn=Y"));
-       assert(res.msgs[0].dnsHostName == "y");
-       assert(res.msgs[0].lastLogon == "y");
-       assert(res.msgs[1].dn == s4.dn("cn=X"));
-       assert(res.msgs[1].dnsHostName == "x");
-       assert(res.msgs[1].lastLogon == "x");
-
-       /* Search by conjunction of remote attributes */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(&(lastLogon=x)(description=x))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 2);
-       assert(res.msgs[0].dn == s4.dn("cn=X"));
-       assert(res.msgs[0].dnsHostName == "x");
-       assert(res.msgs[0].lastLogon == "x");
-       assert(res.msgs[1].dn == s4.dn("cn=A"));
-       assert(res.msgs[1].dnsHostName == undefined);
-       assert(res.msgs[1].lastLogon == "x");
-       
-       /* Search by conjunction of local and remote attribute */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(&(codePage=x)(description=x))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 2);
-       assert(res.msgs[0].dn == s4.dn("cn=Y"));
-       assert(res.msgs[0].dnsHostName == "y");
-       assert(res.msgs[0].lastLogon == "y");
-       assert(res.msgs[1].dn == s4.dn("cn=X"));
-       assert(res.msgs[1].dnsHostName == "x");
-       assert(res.msgs[1].lastLogon == "x");
-
-       /* Search by conjunction of local and remote attribute w/o match */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(&(codePage=x)(nextRid=x))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 0);
-       res = ldb.search("(&(revision=x)(lastLogon=z))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 0);
-
-       /* Search by disjunction of local attributes */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(|(revision=x)(dnsHostName=x))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 2);
-       assert(res.msgs[0].dn == s4.dn("cn=Y"));
-       assert(res.msgs[0].dnsHostName == "y");
-       assert(res.msgs[0].lastLogon == "y");
-       assert(res.msgs[1].dn == s4.dn("cn=X"));
-       assert(res.msgs[1].dnsHostName == "x");
-       assert(res.msgs[1].lastLogon == "x");
-
-       /* Search by disjunction of remote attributes */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(|(badPwdCount=x)(lastLogon=x))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 3);
-       assert(res.msgs[0].dn == s4.dn("cn=B"));
-       assert(res.msgs[0].dnsHostName == undefined);
-       assert(res.msgs[0].lastLogon == "y");
-       assert(res.msgs[1].dn == s4.dn("cn=X"));
-       assert(res.msgs[1].dnsHostName == "x");
-       assert(res.msgs[1].lastLogon == "x");
-       assert(res.msgs[2].dn == s4.dn("cn=A"));
-       assert(res.msgs[2].dnsHostName == undefined);
-       assert(res.msgs[2].lastLogon == "x");
-
-       /* Search by disjunction of local and remote attribute */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(|(revision=x)(lastLogon=y))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 3);
-       assert(res.msgs[0].dn == s4.dn("cn=Y"));
-       assert(res.msgs[0].dnsHostName == "y");
-       assert(res.msgs[0].lastLogon == "y");
-       assert(res.msgs[1].dn == s4.dn("cn=B"));
-       assert(res.msgs[1].dnsHostName == undefined);
-       assert(res.msgs[1].lastLogon == "y");
-       assert(res.msgs[2].dn == s4.dn("cn=X"));
-       assert(res.msgs[2].dnsHostName == "x");
-       assert(res.msgs[2].lastLogon == "x");
-
-       /* Search by disjunction of local and remote attribute w/o match */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(|(codePage=y)(nextRid=z))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 0);
-
-       /* Search by negated local attribute */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(!(revision=x))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 5);
-       assert(res.msgs[0].dn == s4.dn("cn=B"));
-       assert(res.msgs[0].dnsHostName == undefined);
-       assert(res.msgs[0].lastLogon == "y");
-       assert(res.msgs[1].dn == s4.dn("cn=A"));
-       assert(res.msgs[1].dnsHostName == undefined);
-       assert(res.msgs[1].lastLogon == "x");
-       assert(res.msgs[2].dn == s4.dn("cn=Z"));
-       assert(res.msgs[2].dnsHostName == "z");
-       assert(res.msgs[2].lastLogon == "z");
-       assert(res.msgs[3].dn == s4.dn("cn=C"));
-       assert(res.msgs[3].dnsHostName == undefined);
-       assert(res.msgs[3].lastLogon == "z");
-
-       /* Search by negated remote attribute */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(!(description=x))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 3);
-       assert(res.msgs[0].dn == s4.dn("cn=Z"));
-       assert(res.msgs[0].dnsHostName == "z");
-       assert(res.msgs[0].lastLogon == "z");
-       assert(res.msgs[1].dn == s4.dn("cn=C"));
-       assert(res.msgs[1].dnsHostName == undefined);
-       assert(res.msgs[1].lastLogon == "z");
-
-       /* Search by negated conjunction of local attributes */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(!(&(codePage=x)(revision=x)))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 5);
-       assert(res.msgs[0].dn == s4.dn("cn=B"));
-       assert(res.msgs[0].dnsHostName == undefined);
-       assert(res.msgs[0].lastLogon == "y");
-       assert(res.msgs[1].dn == s4.dn("cn=A"));
-       assert(res.msgs[1].dnsHostName == undefined);
-       assert(res.msgs[1].lastLogon == "x");
-       assert(res.msgs[2].dn == s4.dn("cn=Z"));
-       assert(res.msgs[2].dnsHostName == "z");
-       assert(res.msgs[2].lastLogon == "z");
-       assert(res.msgs[3].dn == s4.dn("cn=C"));
-       assert(res.msgs[3].dnsHostName == undefined);
-       assert(res.msgs[3].lastLogon == "z");
-
-       /* Search by negated conjunction of remote attributes */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(!(&(lastLogon=x)(description=x)))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 5);
-       assert(res.msgs[0].dn == s4.dn("cn=Y"));
-       assert(res.msgs[0].dnsHostName == "y");
-       assert(res.msgs[0].lastLogon == "y");
-       assert(res.msgs[1].dn == s4.dn("cn=B"));
-       assert(res.msgs[1].dnsHostName == undefined);
-       assert(res.msgs[1].lastLogon == "y");
-       assert(res.msgs[2].dn == s4.dn("cn=Z"));
-       assert(res.msgs[2].dnsHostName == "z");
-       assert(res.msgs[2].lastLogon == "z");
-       assert(res.msgs[3].dn == s4.dn("cn=C"));
-       assert(res.msgs[3].dnsHostName == undefined);
-       assert(res.msgs[3].lastLogon == "z");
-
-       /* Search by negated conjunction of local and remote attribute */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(!(&(codePage=x)(description=x)))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 5);
-       assert(res.msgs[0].dn == s4.dn("cn=B"));
-       assert(res.msgs[0].dnsHostName == undefined);
-       assert(res.msgs[0].lastLogon == "y");
-       assert(res.msgs[1].dn == s4.dn("cn=A"));
-       assert(res.msgs[1].dnsHostName == undefined);
-       assert(res.msgs[1].lastLogon == "x");
-       assert(res.msgs[2].dn == s4.dn("cn=Z"));
-       assert(res.msgs[2].dnsHostName == "z");
-       assert(res.msgs[2].lastLogon == "z");
-       assert(res.msgs[3].dn == s4.dn("cn=C"));
-       assert(res.msgs[3].dnsHostName == undefined);
-       assert(res.msgs[3].lastLogon == "z");
-
-       /* Search by negated disjunction of local attributes */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(!(|(revision=x)(dnsHostName=x)))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs[0].dn == s4.dn("cn=B"));
-       assert(res.msgs[0].dnsHostName == undefined);
-       assert(res.msgs[0].lastLogon == "y");
-       assert(res.msgs[1].dn == s4.dn("cn=A"));
-       assert(res.msgs[1].dnsHostName == undefined);
-       assert(res.msgs[1].lastLogon == "x");
-       assert(res.msgs[2].dn == s4.dn("cn=Z"));
-       assert(res.msgs[2].dnsHostName == "z");
-       assert(res.msgs[2].lastLogon == "z");
-       assert(res.msgs[3].dn == s4.dn("cn=C"));
-       assert(res.msgs[3].dnsHostName == undefined);
-       assert(res.msgs[3].lastLogon == "z");
-
-       /* Search by negated disjunction of remote attributes */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(!(|(badPwdCount=x)(lastLogon=x)))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 4);
-       assert(res.msgs[0].dn == s4.dn("cn=Y"));
-       assert(res.msgs[0].dnsHostName == "y");
-       assert(res.msgs[0].lastLogon == "y");
-       assert(res.msgs[1].dn == s4.dn("cn=Z"));
-       assert(res.msgs[1].dnsHostName == "z");
-       assert(res.msgs[1].lastLogon == "z");
-       assert(res.msgs[2].dn == s4.dn("cn=C"));
-       assert(res.msgs[2].dnsHostName == undefined);
-       assert(res.msgs[2].lastLogon == "z");
-
-       /* Search by negated disjunction of local and remote attribute */
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(!(|(revision=x)(lastLogon=y)))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 4);
-       assert(res.msgs[0].dn == s4.dn("cn=A"));
-       assert(res.msgs[0].dnsHostName == undefined);
-       assert(res.msgs[0].lastLogon == "x");
-       assert(res.msgs[1].dn == s4.dn("cn=Z"));
-       assert(res.msgs[1].dnsHostName == "z");
-       assert(res.msgs[1].lastLogon == "z");
-       assert(res.msgs[2].dn == s4.dn("cn=C"));
-       assert(res.msgs[2].dnsHostName == undefined);
-       assert(res.msgs[2].lastLogon == "z");
-
-       println("Search by complex parse tree");
-       attrs = new Array("dnsHostName", "lastLogon");
-       res = ldb.search("(|(&(revision=x)(dnsHostName=x))(!(&(description=x)(nextRid=y)))(badPwdCount=y))", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 6);
-       assert(res.msgs[0].dn == s4.dn("cn=B"));
-       assert(res.msgs[0].dnsHostName == undefined);
-       assert(res.msgs[0].lastLogon == "y");
-       assert(res.msgs[1].dn == s4.dn("cn=X"));
-       assert(res.msgs[1].dnsHostName == "x");
-       assert(res.msgs[1].lastLogon == "x");
-       assert(res.msgs[2].dn == s4.dn("cn=A"));
-       assert(res.msgs[2].dnsHostName == undefined);
-       assert(res.msgs[2].lastLogon == "x");
-       assert(res.msgs[3].dn == s4.dn("cn=Z"));
-       assert(res.msgs[3].dnsHostName == "z");
-       assert(res.msgs[3].lastLogon == "z");
-       assert(res.msgs[4].dn == s4.dn("cn=C"));
-       assert(res.msgs[4].dnsHostName == undefined);
-       assert(res.msgs[4].lastLogon == "z");
-
-       /* Clean up */
-       var dns = new Array();
-       dns[0] = s4.dn("cn=A");
-       dns[1] = s4.dn("cn=B");
-       dns[2] = s4.dn("cn=C");
-       dns[3] = s4.dn("cn=X");
-       dns[4] = s4.dn("cn=Y");
-       dns[5] = s4.dn("cn=Z");
-       for (i=0;i<dns.length;i++) {
-               var ok = ldb.del(dns[i]);
-               assert(ok.error == 0);
-       }
-}
-
-function test_map_modify(ldb, s3, s4)
-{
-       println("Running modification tests on mapped data");
-
-       var ldif;
-       var attrs;
-       var dn, dn2;
-       var res;
-       var ok;
-
-       println("Testing modification of local records");
-
-       /* Add local record */
-       dn = "cn=test,dc=idealx,dc=org";
-       ldif = "
-dn: " + dn + "
-cn: test
-foo: bar
-revision: 1
-description: test
-";
-       ok = ldb.add(ldif);
-       assert(ok.error == 0);
-       /* Check it's there */
-       attrs = new Array("foo", "revision", "description");
-       res = ldb.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].foo == "bar");
-       assert(res.msgs[0].revision == "1");
-       assert(res.msgs[0].description == "test");
-       /* Check it's not in the local db */
-       res = s4.db.search("(cn=test)", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 0);
-       /* Check it's not in the remote db */
-       res = s3.db.search("(cn=test)", NULL, ldb.SCOPE_DEFAULT, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 0);
-
-       /* Modify local record */
-       ldif = "
-dn: " + dn + "
-replace: foo
-foo: baz
-replace: description
-description: foo
-";
-       ok = ldb.modify(ldif);
-       assert(ok.error == 0);
-       /* Check in local db */
-       res = ldb.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].foo == "baz");
-       assert(res.msgs[0].revision == "1");
-       assert(res.msgs[0].description == "foo");
-
-       /* Rename local record */
-       dn2 = "cn=toast,dc=idealx,dc=org";
-       ok = ldb.rename(dn, dn2);
-       assert(ok.error == 0);
-       /* Check in local db */
-       res = ldb.search("", dn2, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn2);
-       assert(res.msgs[0].foo == "baz");
-       assert(res.msgs[0].revision == "1");
-       assert(res.msgs[0].description == "foo");
-
-       /* Delete local record */
-       ok = ldb.del(dn2);
-       assert(ok.error == 0);
-       /* Check it's gone */
-       res = ldb.search("", dn2, ldb.SCOPE_BASE);
-       assert(res.error == 0);
-       assert(res.msgs.length == 0);
-
-       println("Testing modification of remote records");
-
-       /* Add remote record */
-       dn = s4.dn("cn=test");
-       dn2 = s3.dn("cn=test");
-       ldif = "
-dn: " + dn2 + "
-cn: test
-description: foo
-sambaBadPasswordCount: 3
-sambaNextRid: 1001
-";
-       ok = s3.db.add(ldif);
-       assert(ok.error == 0);
-       /* Check it's there */
-       attrs = new Array("description", "sambaBadPasswordCount", "sambaNextRid");
-       res = s3.db.search("", dn2, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn2);
-       assert(res.msgs[0].description == "foo");
-       assert(res.msgs[0].sambaBadPasswordCount == "3");
-       assert(res.msgs[0].sambaNextRid == "1001");
-       /* Check in mapped db */
-       attrs = new Array("description", "badPwdCount", "nextRid");
-       res = ldb.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].description == "foo");
-       assert(res.msgs[0].badPwdCount == "3");
-       assert(res.msgs[0].nextRid == "1001");
-       /* Check in local db */
-       res = s4.db.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 0);
-
-       /* Modify remote data of remote record */
-       ldif = "
-dn: " + dn + "
-replace: description
-description: test
-replace: badPwdCount
-badPwdCount: 4
-";
-       ok = ldb.modify(ldif);
-       /* Check in mapped db */
-       attrs = new Array("description", "badPwdCount", "nextRid");
-       res = ldb.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].description == "test");
-       assert(res.msgs[0].badPwdCount == "4");
-       assert(res.msgs[0].nextRid == "1001");
-       /* Check in remote db */
-       attrs = new Array("description", "sambaBadPasswordCount", "sambaNextRid");
-       res = s3.db.search("", dn2, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn2);
-       assert(res.msgs[0].description == "test");
-       assert(res.msgs[0].sambaBadPasswordCount == "4");
-       assert(res.msgs[0].sambaNextRid == "1001");
-
-       /* Rename remote record */
-       dn2 = s4.dn("cn=toast");
-       ok = ldb.rename(dn, dn2);
-       assert(ok.error == 0);
-       /* Check in mapped db */
-       dn = dn2;
-       attrs = new Array("description", "badPwdCount", "nextRid");
-       res = ldb.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].description == "test");
-       assert(res.msgs[0].badPwdCount == "4");
-       assert(res.msgs[0].nextRid == "1001");
-       /* Check in remote db */
-       dn2 = s3.dn("cn=toast");
-       attrs = new Array("description", "sambaBadPasswordCount", "sambaNextRid");
-       res = s3.db.search("", dn2, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn2);
-       assert(res.msgs[0].description == "test");
-       assert(res.msgs[0].sambaBadPasswordCount == "4");
-       assert(res.msgs[0].sambaNextRid == "1001");
-
-       /* Delete remote record */
-       ok = ldb.del(dn);
-       assert(ok.error == 0);
-       /* Check in mapped db */
-       res = ldb.search("", dn, ldb.SCOPE_BASE);
-       assert(res.error == 0);
-       assert(res.msgs.length == 0);
-       /* Check in remote db */
-       res = s3.db.search("", dn2, ldb.SCOPE_BASE);
-       assert(res.error == 0);
-       assert(res.msgs.length == 0);
-
-       /* Add remote record (same as before) */
-       dn = s4.dn("cn=test");
-       dn2 = s3.dn("cn=test");
-       ldif = "
-dn: " + dn2 + "
-cn: test
-description: foo
-sambaBadPasswordCount: 3
-sambaNextRid: 1001
-";
-       ok = s3.db.add(ldif);
-       assert(ok.error == 0);
-
-       /* Modify local data of remote record */
-       ldif = "
-dn: " + dn + "
-add: revision
-revision: 1
-replace: description
-description: test
-";
-       ok = ldb.modify(ldif);
-       /* Check in mapped db */
-       attrs = new Array("revision", "description");
-       res = ldb.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].description == "test");
-       assert(res.msgs[0].revision == "1");
-       /* Check in remote db */
-       res = s3.db.search("", dn2, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn2);
-       assert(res.msgs[0].description == "test");
-       assert(res.msgs[0].revision == undefined);
-       /* Check in local db */
-       res = s4.db.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].description == undefined);
-       assert(res.msgs[0].revision == "1");
-
-       /* Delete (newly) split record */
-       ok = ldb.del(dn);
-       assert(ok.error == 0);
-
-       println("Testing modification of split records");
-
-       /* Add split record */
-       dn = s4.dn("cn=test");
-       dn2 = s3.dn("cn=test");
-       ldif = "
-dn: " + dn + "
-cn: test
-description: foo
-badPwdCount: 3
-nextRid: 1001
-revision: 1
-";
-       ok = ldb.add(ldif);
-       assert(ok.error == 0);
-       /* Check it's there */
-       attrs = new Array("description", "badPwdCount", "nextRid", "revision");
-       res = ldb.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].description == "foo");
-       assert(res.msgs[0].badPwdCount == "3");
-       assert(res.msgs[0].nextRid == "1001");
-       assert(res.msgs[0].revision == "1");
-       /* Check in local db */
-       res = s4.db.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].description == undefined);
-       assert(res.msgs[0].badPwdCount == undefined);
-       assert(res.msgs[0].nextRid == undefined);
-       assert(res.msgs[0].revision == "1");
-       /* Check in remote db */
-       attrs = new Array("description", "sambaBadPasswordCount", "sambaNextRid", "revision");
-       res = s3.db.search("", dn2, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn2);
-       assert(res.msgs[0].description == "foo");
-       assert(res.msgs[0].sambaBadPasswordCount == "3");
-       assert(res.msgs[0].sambaNextRid == "1001");
-       assert(res.msgs[0].revision == undefined);
-
-       /* Modify of split record */
-       ldif = "
-dn: " + dn + "
-replace: description
-description: test
-replace: badPwdCount
-badPwdCount: 4
-replace: revision
-revision: 2
-";
-       ok = ldb.modify(ldif);
-       assert(ok.error == 0);
-       /* Check in mapped db */
-       attrs = new Array("description", "badPwdCount", "nextRid", "revision");
-       res = ldb.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].description == "test");
-       assert(res.msgs[0].badPwdCount == "4");
-       assert(res.msgs[0].nextRid == "1001");
-       assert(res.msgs[0].revision == "2");
-       /* Check in local db */
-       res = s4.db.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].description == undefined);
-       assert(res.msgs[0].badPwdCount == undefined);
-       assert(res.msgs[0].nextRid == undefined);
-       assert(res.msgs[0].revision == "2");
-       /* Check in remote db */
-       attrs = new Array("description", "sambaBadPasswordCount", "sambaNextRid", "revision");
-       res = s3.db.search("", dn2, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn2);
-       assert(res.msgs[0].description == "test");
-       assert(res.msgs[0].sambaBadPasswordCount == "4");
-       assert(res.msgs[0].sambaNextRid == "1001");
-       assert(res.msgs[0].revision == undefined);
-
-       /* Rename split record */
-       dn2 = s4.dn("cn=toast");
-       ok = ldb.rename(dn, dn2);
-       assert(ok.error == 0);
-       /* Check in mapped db */
-       dn = dn2;
-       attrs = new Array("description", "badPwdCount", "nextRid", "revision");
-       res = ldb.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].description == "test");
-       assert(res.msgs[0].badPwdCount == "4");
-       assert(res.msgs[0].nextRid == "1001");
-       assert(res.msgs[0].revision == "2");
-       /* Check in local db */
-       res = s4.db.search("", dn, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn);
-       assert(res.msgs[0].description == undefined);
-       assert(res.msgs[0].badPwdCount == undefined);
-       assert(res.msgs[0].nextRid == undefined);
-       assert(res.msgs[0].revision == "2");
-       /* Check in remote db */
-       dn2 = s3.dn("cn=toast");
-       attrs = new Array("description", "sambaBadPasswordCount", "sambaNextRid", "revision");
-       res = s3.db.search("", dn2, ldb.SCOPE_BASE, attrs);
-       assert(res.error == 0);
-       assert(res.msgs.length == 1);
-       assert(res.msgs[0].dn == dn2);
-       assert(res.msgs[0].description == "test");
-       assert(res.msgs[0].sambaBadPasswordCount == "4");
-       assert(res.msgs[0].sambaNextRid == "1001");
-       assert(res.msgs[0].revision == undefined);
-
-       /* Delete split record */
-       ok = ldb.del(dn);
-       assert(ok.error == 0);
-       /* Check in mapped db */
-       res = ldb.search("", dn, ldb.SCOPE_BASE);
-       assert(res.error == 0);
-       assert(res.msgs.length == 0);
-       /* Check in local db */
-       res = s4.db.search("", dn, ldb.SCOPE_BASE);
-       assert(res.error == 0);
-       assert(res.msgs.length == 0);
-       /* Check in remote db */
-       res = s3.db.search("", dn2, ldb.SCOPE_BASE);
-       assert(res.error == 0);
-       assert(res.msgs.length == 0);
-}
-
-function make_dn(rdn)
-{
-       return rdn + ",sambaDomainName=TESTS," + this.BASEDN;
-}
-
-function make_s4dn(rdn)
-{
-       return rdn + "," + this.BASEDN;
-}
-
-var ldb = ldb_init();
-
-sys = sys_init();
-var ldbfile = prefix + "/" + "test.ldb";
-var ldburl = "tdb://" + ldbfile;
-
-var samba4 = new Object("samba4 partition info");
-samba4.file = prefix + "/" + "samba4.ldb";
-samba4.url = "tdb://" + samba4.file;
-samba4.BASEDN = "dc=vernstok,dc=nl";
-samba4.db = ldb_init();
-samba4.dn = make_s4dn;
-
-var samba3 = new Object("samba3 partition info");
-samba3.file = prefix + "/" + "samba3.ldb";
-samba3.url = "tdb://" + samba3.file;
-samba3.BASEDN = "cn=Samba3Sam";
-samba3.db = ldb_init();
-samba3.dn = make_dn;
-
-var templates = new Object("templates partition info");
-templates.file = prefix + "/" + "templates.ldb";
-templates.url = "tdb://" + templates.file;
-templates.BASEDN = "cn=templates";
-templates.db = ldb_init();
-
-sys.unlink(ldbfile);
-sys.unlink(samba3.file);
-sys.unlink(templates.file);
-sys.unlink(samba4.file);
-
-var ok = ldb.connect(ldburl);
-assert(ok);
-var ok = samba3.db.connect(samba3.url);
-assert(ok);
-var ok = templates.db.connect(templates.url);
-assert(ok);
-var ok = samba4.db.connect(samba4.url);
-assert(ok);
-
-setup_data(samba3, sys.file_load(datadir + "/" + "samba3.ldif"));
-setup_data(templates, sys.file_load(datadir + "/" + "provision_samba3sam_templates.ldif"));
-setup_modules(ldb, samba3, samba4, sys.file_load(datadir + "/" + "provision_samba3sam.ldif"));
-
-ldb = ldb_init();
-var ok = ldb.connect(ldburl);
-assert(ok);
-
-test_s3sam_search(ldb);
-test_s3sam_modify(ldb, samba3);
-
-sys.unlink(ldbfile);
-sys.unlink(samba3.file);
-sys.unlink(templates.file);
-sys.unlink(samba4.file);
-
-ldb = ldb_init();
-var ok = ldb.connect(ldburl);
-assert(ok);
-samba3.db = ldb_init();
-var ok = samba3.db.connect(samba3.url);
-assert(ok);
-templates.db = ldb_init();
-var ok = templates.db.connect(templates.url);
-assert(ok);
-samba4.db = ldb_init();
-var ok = samba4.db.connect(samba4.url);
-assert(ok);
-
-setup_data(templates, sys.file_load(datadir + "/" + "provision_samba3sam_templates.ldif"));
-setup_modules(ldb, samba3, samba4, sys.file_load(datadir + "provision_samba3sam.ldif"));
-
-ldb = ldb_init();
-var ok = ldb.connect(ldburl);
-assert(ok);
-
-test_map_search(ldb, samba3, samba4);
-test_map_modify(ldb, samba3, samba4);
-
-sys.unlink(ldbfile);
-sys.unlink(samba3.file);
-sys.unlink(samba4.file);
-
-return 0;