]> git.sur5r.net Git - openldap/blobdiff - tests/scripts/test000-rootdse
Fix prev commit, better test for multiple URI matches
[openldap] / tests / scripts / test000-rootdse
index 2526dfe2d2f5ec925b58eabf0bfb464fe2771467..635b9fff6b8e80d23d4081312a62c600049422af 100755 (executable)
@@ -2,7 +2,7 @@
 # $OpenLDAP$
 ## This work is part of OpenLDAP Software <http://www.openldap.org/>.
 ##
-## Copyright 1998-2003 The OpenLDAP Foundation.
+## Copyright 1998-2006 The OpenLDAP Foundation.
 ## All rights reserved.
 ##
 ## Redistribution and use in source and binary forms, with or without
@@ -16,7 +16,7 @@
 echo "running defines.sh"
 . $SRCDIR/scripts/defines.sh
 
-mkdir -p $TESTRUN $DBDIR1
+mkdir -p $TESTDIR $DBDIR1
 
 echo "Starting slapd on TCP/IP port $PORT1..."
 . $CONFFILTER $BACKEND $MONITORDB < $SCHEMACONF > $CONF1
@@ -28,9 +28,12 @@ if test $WAIT != 0 ; then
 fi
 KILLPIDS="$PID"
 
+sleep 1
+
 echo "Using ldapsearch to retrieve the root DSE..."
 for i in 0 1 2 3 4 5; do
-       $LDAPSEARCH -b "" -s base -h $LOCALHOST -p $PORT1 '+extensibleObject' > $SEARCHOUT 2>&1
+       $LDAPSEARCH -b "" -s base -h $LOCALHOST -p $PORT1 \
+               '+extensibleObject' > $SEARCHOUT 2>&1
        RC=$?
        if test $RC = 0 ; then
                break
@@ -39,24 +42,45 @@ for i in 0 1 2 3 4 5; do
        sleep 5
 done
 
-if test $RC = 0 -a $MONITORDB = yes ; then
-       echo "Using ldapsearch to retrieve the cn=Monitor..."
-       $LDAPSEARCH -b "cn=Monitor" -s base -h $LOCALHOST -p $PORT1 '+extensibleObject' >> $SEARCHOUT 2>&1
+if test $RC = 0 ; then
+       echo "Using ldapsearch to retrieve the cn=Subschema..."
+       $LDAPSEARCH -b "cn=Subschema" -s base -h $LOCALHOST -p $PORT1 \
+               '(&(objectClasses=top)(objectClasses=2.5.6.0))' cn objectClass \
+               >> $SEARCHOUT  2>&1
        RC=$?
+
+fi
+
+count=2
+if test $RC = 0 ; then
+       case $MONITORDB in yes | mod)
+               count=3
+               echo "Using ldapsearch to retrieve the cn=Monitor..."
+               $LDAPSEARCH -b "cn=Monitor" -s base -h $LOCALHOST -p $PORT1 \
+                       '+extensibleObject' >> $SEARCHOUT 2>&1
+               RC=$?
+               ;;
+       esac
 fi
 
 test $KILLSERVERS != no && kill -HUP $KILLPIDS
 
 cat $SEARCHOUT
 
+
 if test $RC != 0 ; then
        echo ">>>>> Test failed"
 else
-       if grep "TLS:" $SEARCHOUT; then
-               RC=-1
+       RC=`grep '^dn:' $SEARCHOUT | wc -l`
+       if test $RC != $count ; then
+               echo ">>>>> Test failed: expected $count entries, got" $RC
+               RC=1
        else
-           echo ">>>>> Test succeeded"
+               echo ">>>>> Test succeeded"
+               RC=0
        fi
 fi
 
+test $KILLSERVERS != no && wait
+
 exit $RC