]> git.sur5r.net Git - openldap/blobdiff - tests/scripts/test023-refint
s/ldap_sync.h/ldap.h/
[openldap] / tests / scripts / test023-refint
index fb1687cff50121dbce1f334aeeb8bf00018943d7..4caf801248a75c291f06f9fdcab1c3e8f471498d 100755 (executable)
@@ -2,7 +2,7 @@
 # $OpenLDAP$
 ## This work is part of OpenLDAP Software <http://www.openldap.org/>.
 ##
-## Copyright 2004-2005 The OpenLDAP Foundation.
+## Copyright 2004-2008 The OpenLDAP Foundation.
 ## All rights reserved.
 ##
 ## Redistribution and use in source and binary forms, with or without
@@ -46,6 +46,8 @@ if test $WAIT != 0 ; then
 fi
 KILLPIDS="$PID"
 
+sleep 1
+
 echo "Testing slapd referential integrity operations..."
 for i in 0 1 2 3 4 5; do
        $LDAPSEARCH -s base -b "$MONITOR" -h $LOCALHOST -p $PORT1 \
@@ -90,6 +92,8 @@ if test $RC != 0 ; then
        exit $RC
 fi
 
+sleep 1;
+
 echo "Using ldapsearch to check dependents new rdn..."
 
 $LDAPSEARCH -S "" -b "o=refint" -h $LOCALHOST -p $PORT1 > $SEARCHOUT 2>&1
@@ -127,6 +131,8 @@ if test $RC != 0 ; then
        exit $RC
 fi
 
+sleep 1;
+
 echo "Using ldapsearch to verify dependents have been deleted..."
 $LDAPSEARCH -S "" -b "o=refint" -h $LOCALHOST -p $PORT1 > $SEARCHOUT 2>&1
 
@@ -152,6 +158,7 @@ $LDAPADD -D "$REFINTDN" -h $LOCALHOST -p $PORT1 -w $PASSWD > \
        $TESTOUT 2>&1 << ETEST
 dn: uid=special,ou=users,o=refint
 objectClass: inetOrgPerson
+objectClass: extensibleObject
 uid: special
 sn: special
 cn: special
@@ -165,6 +172,13 @@ givenName: special
 member: uid=alice,ou=users,o=refint
 ETEST
 
+RC=$?
+if test $RC != 0 ; then
+       echo "ldapadd failed ($RC)!"
+       test $KILLSERVERS != no && kill -HUP $KILLPIDS
+       exit $RC
+fi
+
 echo "Testing delete when referential attribute is a MUST..."
 $LDAPMODIFY -v -D "$REFINTDN" -h $LOCALHOST -p $PORT1 -w $PASSWD > \
        $TESTOUT 2>&1 << EDEL
@@ -180,7 +194,85 @@ if test $RC != 0 ; then
        exit $RC
 fi
 
+if test $BACKEND = "hdb" ; then
+       $LDAPMODIFY -v -D "$REFINTDN" -h $LOCALHOST -p $PORT1 -w $PASSWD > \
+               $TESTOUT 2>&1 << EDEL
+version: 1
+dn: cn=group,o=refint
+changetype: add
+objectClass: groupOfNames
+cn: group
+member: uid=bill,ou=users,o=refint
+member: uid=bob,ou=users,o=refint
+member: uid=dave,ou=users,o=refint
+member: uid=jorge,ou=users,o=refint
+member: uid=theman,ou=users,o=refint
+member: uid=richard,ou=users,o=refint
+EDEL
+
+       RC=$?
+       if test $RC != 0 ; then
+               echo "ldapmodify failed ($RC)!"
+               test $KILLSERVERS != no && kill -HUP $KILLPIDS
+               exit $RC
+       fi
+
+       sleep 1;
+
+       $LDAPSEARCH -S "" -b "o=refint" -h $LOCALHOST -p $PORT1 \
+               manager member secretary > $SEARCHOUT 2>&1
+       RC=$?
+       if test $RC != 0 ; then
+               echo "ldapsearch failed ($RC)!"
+               test $KILLSERVERS != no && kill -HUP $KILLPIDS
+               exit $RC
+       fi
+
+       $EGREP_CMD "(manager|member|secretary):" $SEARCHOUT \
+               | sed "s/ou=users/ou=people/g" | \
+               sort > $TESTOUT 2>&1
+
+       echo "testing subtree rename"
+       $LDAPMODRDN -D "$REFINTDN" -r -h $LOCALHOST -p $PORT1 -w $PASSWD > \
+               /dev/null 2>&1 'ou=users,o=refint' 'ou=people'
+       RC=$?
+       if test $RC != 0 ; then
+               echo "ldapmodrdn failed ($RC)!"
+               test $KILLSERVERS != no && kill -HUP $KILLPIDS
+               exit $RC
+       fi
+
+       sleep 1;
+
+       echo "Using ldapsearch to check dependents new rdn..."
+
+       $LDAPSEARCH -S "" -b "o=refint" -h $LOCALHOST -p $PORT1 \
+               manager member secretary > $SEARCHOUT 2>&1
+
+       RC=$?
+       if test $RC != 0 ; then
+               echo "ldapsearch failed ($RC)!"
+               test $KILLSERVERS != no && kill -HUP $KILLPIDS
+               exit $RC
+       fi
+
+       $EGREP_CMD "(manager|member|secretary):" $SEARCHOUT \
+               | sort > $SEARCHFLT 2>&1
+
+       echo "Comparing ldapsearch results against original..."
+       $CMP $TESTOUT $SEARCHFLT > $CMPOUT
+
+       if test $? != 0 ; then
+               echo "comparison failed - subtree rename operations did not complete correctly"
+               test $KILLSERVERS != no && kill -HUP $KILLPIDS
+               exit 1
+       fi
+fi
+
 test $KILLSERVERS != no && kill -HUP $KILLPIDS
 
 echo ">>>>> Test succeeded"
+
+test $KILLSERVERS != no && wait
+
 exit 0