]> git.sur5r.net Git - openldap/commitdiff
Add basic referral test.
authorKurt Zeilenga <kurt@openldap.org>
Thu, 15 Jul 1999 20:31:17 +0000 (20:31 +0000)
committerKurt Zeilenga <kurt@openldap.org>
Thu, 15 Jul 1999 20:31:17 +0000 (20:31 +0000)
tests/data/slapd-ref-slave.conf [new file with mode: 0644]
tests/data/slapd-repl-slave.conf
tests/data/slapd.oc.conf
tests/scripts/defines.sh
tests/scripts/test009-referral [new file with mode: 0755]

diff --git a/tests/data/slapd-ref-slave.conf b/tests/data/slapd-ref-slave.conf
new file mode 100644 (file)
index 0000000..adfde5f
--- /dev/null
@@ -0,0 +1,25 @@
+#
+# master slapd config -- for referral testing
+#
+include                ./data/slapd.at.conf
+include                ./data/slapd.oc.conf
+schemacheck    off
+pidfile     ./test-repl/slapd.pid
+argsfile    ./test-repl/slapd.args
+
+#######################################################################
+# ldbm database definitions
+#######################################################################
+
+referral       "ldap://hostG/"
+
+database       ldbm
+cachesize      0
+suffix         "c=US"
+directory      ./test-repl
+rootdn         "cn=Manager, o=University of Michigan, c=US"
+rootpw         secret
+index          cn,sn,uid       pres,eq,approx
+index          default         none
+# index                default         pres,eq,approx
+lastmod                on
index ca81b76529d5c2443970cebe24581ea05b68bc90..d73acd0a0235fb385daf47ecf5cbd0e38b537744 100644 (file)
@@ -4,17 +4,24 @@
 include                ./data/slapd.at.conf
 include                ./data/slapd.oc.conf
 schemacheck    off
+pidfile     ./test-repl/slapd.pid
+argsfile    ./test-repl/slapd.args
+
+referral       "ldap://localhost:9009/"
 
 #######################################################################
 # ldbm database definitions
 #######################################################################
 
 database       ldbm
+cachesize      0
 suffix         "o=University of Michigan, c=US"
 directory      ./test-repl
 rootdn         "cn=Manager, o=University of Michigan, c=US"
 rootpw         secret
 updatedn       "cn=Manager, o=University of Michigan, c=US"
+updateref      "ldap://localhost:9009/o=University of Michigan,c=US"
 index          cn,sn,uid       pres,eq,approx
 index          default         none
+# index                default         pres,eq,approx
 lastmod                on
index 5ff324314361ba30d4774a69e1b235373fe426b2..fe077cdfa3d4a6326c872bf1c0d634230f0e3b40 100644 (file)
@@ -9,7 +9,7 @@ objectclass alias
 
 objectclass referral
        requires
-               ref
+               ref,
                objectClass
 
 objectclass country
index c45657138db67aad0908a1c17270771e74ea7d58..418ea44df23aa69231919403be625fc96f0aad8b 100755 (executable)
@@ -15,6 +15,7 @@ else
        ACLCONF=$DATADIR/slapd-acl.conf
        MASTERCONF=$DATADIR/slapd-repl-master.conf
        SLAVECONF=$DATADIR/slapd-repl-slave.conf
+       REFSLAVECONF=$DATADIR/slapd-ref-slave.conf
 fi
 
 if test "$LDAP_PROTO" ; then
diff --git a/tests/scripts/test009-referral b/tests/scripts/test009-referral
new file mode 100755 (executable)
index 0000000..e00fbba
--- /dev/null
@@ -0,0 +1,125 @@
+#! /bin/sh
+
+#
+# Test simple slave->master referral
+#
+
+if test $# -eq 0 ; then
+       SRCDIR="."
+else
+       SRCDIR=$1; shift
+fi
+if test $# -eq 1 ; then
+       BACKEND=$1; shift
+fi
+
+echo "running defines.sh $SRCDIR $BACKEND"
+. $SRCDIR/scripts/defines.sh
+
+echo "Cleaning up in $DBDIR..."
+
+rm -f $DBDIR/[!C]*
+
+echo "Running ldif2ldbm to build slapd database..."
+$LDIF2LDBM -f $CONF -i $LDIF -e ../servers/slapd/tools
+RC=$?
+if test $RC != 0 ; then
+       echo "ldif2ldbm failed!"
+       exit $RC
+fi
+
+echo "Starting master slapd on TCP/IP port $PORT..."
+$SLAPD -f $CONF -p $PORT -d $LVL $TIMING > $MASTERLOG 2>&1 &
+PID=$!
+
+echo "Starting slave slapd on TCP/IP port $SLAVEPORT..."
+$SLAPD -f $REFSLAVECONF -p $SLAVEPORT -d $LVL $TIMING > $SLAVELOG 2>&1 &
+SLAVEPID=$!
+
+echo "Testing for master slapd..."
+for i in 0 1 2 3 4 5; do
+       $LDAPSEARCH -L -s base -b "$MONITOR" -h localhost -p $PORT \
+               'objectclass=*' > /dev/null 2>&1
+       RC=$?
+       if test $RC = 1 ; then
+               echo "Waiting 5 seconds for slapd to start..."
+               sleep 5
+       fi
+done
+
+if test $RC != 0 ; then
+       echo "ldapsearch failed!"
+       kill -HUP $PID
+       exit $RC
+fi
+
+echo "Testing for slave slapd..."
+for i in 0 1 2 3 4 5; do
+       $LDAPSEARCH -L -s base -b "$MONITOR" -h localhost -p $SLAVEPORT \
+               'objectclass=*' > /dev/null 2>&1
+       RC=$?
+       if test $RC = 1 ; then
+               echo "Waiting 5 seconds for slapd to start..."
+               sleep 5
+       fi
+done
+
+cat /dev/null > $SEARCHOUT
+
+echo "Testing exact searching..."
+$LDAPSEARCH -L -S "" -b "$BASEDN" -h localhost -p $SLAVEPORT \
+       'sn=jensen' >> $SEARCHOUT 2>&1
+if test $RC != 0 ; then
+       echo "ldapsearch failed!"
+       kill -HUP $PID $SLAVEPID
+       exit $RC
+fi
+
+echo "Testing OR searching..."
+$LDAPSEARCH -L -S "" -b "$BASEDN" -h localhost -p $SLAVEPORT \
+       '(|(objectclass=rfc822mailgroup)(sn=jones))' >> $SEARCHOUT 2>&1
+if test $RC != 0 ; then
+       echo "ldapsearch failed!"
+       kill -HUP $PID $SLAVEPID
+       exit $RC
+fi
+
+echo "Testing AND matching and ends-with searching..."
+$LDAPSEARCH -L -S "" -b "$BASEDN" -h localhost -p $SLAVEPORT \
+       '(&(objectclass=rfc822mailgroup)(cn=A*))' >> $SEARCHOUT 2>&1
+if test $RC != 0 ; then
+       echo "ldapsearch failed!"
+       kill -HUP $PID $SLAVEPID
+       exit $RC
+fi
+
+echo "Testing NOT searching..."
+$LDAPSEARCH -L -S "" -b "$BASEDN" -h localhost -p $SLAVEPORT \
+       '(!(objectclass=person))' >> $SEARCHOUT 2>&1
+if test $RC != 0 ; then
+       echo "ldapsearch failed!"
+       kill -HUP $PID $SLAVEPID
+       exit $RC
+fi
+
+kill -HUP $PID $SLAVEPID
+
+TESTOUT=$SEARCHOUT
+LDIF=$SEARCHOUTMASTER
+
+echo "Filtering ldapsearch results..."
+. $SRCDIR/scripts/acfilter.sh < $SEARCHOUT > $SEARCHFLT
+echo "Filtering original ldif used to create database..."
+. $SRCDIR/scripts/acfilter.sh < $LDIF > $LDIFFLT
+echo "Comparing filter output..."
+cmp $SEARCHFLT $LDIFFLT
+
+if test $? != 0 ; then
+       echo "Comparison failed"
+       exit 1
+fi
+
+echo ">>>>> Test succeeded"
+
+
+exit 0