From b26c3d978096b6f4b1d854ad31e2fcf2a35e6c60 Mon Sep 17 00:00:00 2001 From: Kurt Zeilenga Date: Thu, 15 Jul 1999 20:31:17 +0000 Subject: [PATCH] Add basic referral test. --- tests/data/slapd-ref-slave.conf | 25 +++++++ tests/data/slapd-repl-slave.conf | 7 ++ tests/data/slapd.oc.conf | 2 +- tests/scripts/defines.sh | 1 + tests/scripts/test009-referral | 125 +++++++++++++++++++++++++++++++ 5 files changed, 159 insertions(+), 1 deletion(-) create mode 100644 tests/data/slapd-ref-slave.conf create mode 100755 tests/scripts/test009-referral diff --git a/tests/data/slapd-ref-slave.conf b/tests/data/slapd-ref-slave.conf new file mode 100644 index 0000000000..adfde5f24f --- /dev/null +++ b/tests/data/slapd-ref-slave.conf @@ -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 diff --git a/tests/data/slapd-repl-slave.conf b/tests/data/slapd-repl-slave.conf index ca81b76529..d73acd0a02 100644 --- a/tests/data/slapd-repl-slave.conf +++ b/tests/data/slapd-repl-slave.conf @@ -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 diff --git a/tests/data/slapd.oc.conf b/tests/data/slapd.oc.conf index 5ff3243143..fe077cdfa3 100644 --- a/tests/data/slapd.oc.conf +++ b/tests/data/slapd.oc.conf @@ -9,7 +9,7 @@ objectclass alias objectclass referral requires - ref + ref, objectClass objectclass country diff --git a/tests/scripts/defines.sh b/tests/scripts/defines.sh index c45657138d..418ea44df2 100755 --- a/tests/scripts/defines.sh +++ b/tests/scripts/defines.sh @@ -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 index 0000000000..e00fbbaf64 --- /dev/null +++ b/tests/scripts/test009-referral @@ -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 -- 2.39.5