]> git.sur5r.net Git - openldap/blob - tests/scripts/test009-referral
Updates for back-bdb testing
[openldap] / tests / scripts / test009-referral
1 #! /bin/sh
2 # $OpenLDAP$
3
4 SRCDIR="."
5 if test $# -ge 1 ; then
6         SRCDIR=$1; shift
7 fi
8 BACKEND=ldbm
9 if test $# -ge 1 ; then
10         BACKEND=$1; shift
11 fi
12
13 echo "running defines.sh"
14 . $SRCDIR/scripts/defines.sh
15
16 #
17 # Test default referral
18 #
19
20
21 echo "Cleaning up in $DBDIR and $REPLDIR ..."
22
23 rm -f $DBDIR/[!C]*
24 rm -f $REPLDIR/[!C]*
25
26 echo "Running slapadd to build slapd database..."
27 . $CONFFILTER $BACKEND < $CONF > $DBCONF
28 $SLAPADD -f $DBCONF -l $LDIFORDERED
29 RC=$?
30 if test $RC != 0 ; then
31         echo "slapadd failed ($RC)!"
32         exit $RC
33 fi
34
35 echo "Starting master slapd on TCP/IP port $PORT..."
36 $SLAPD -n master -f $DBCONF -h $MASTERURI -d $LVL $TIMING > $MASTERLOG 2>&1 &
37 PID=$!
38
39 echo "Starting slave slapd on TCP/IP port $SLAVEPORT..."
40 . $CONFFILTER $BACKEND < $REFSLAVECONF > $REPLCONF
41 $SLAPD -n slave -f $REPLCONF -h $SLAVEURI -d $LVL $TIMING > $SLAVELOG 2>&1 &
42 SLAVEPID=$!
43
44 echo "Testing for master slapd..."
45 for i in 0 1 2 3 4 5; do
46         $LDAPSEARCH -s base -b "$MONITOR" -h localhost -p $PORT \
47                 'objectclass=*' > /dev/null 2>&1
48         RC=$?
49         if test $RC = 1 ; then
50                 echo "Waiting 5 seconds for slapd to start..."
51                 sleep 5
52         fi
53 done
54
55 if test $RC != 0 ; then
56         echo "ldapsearch failed ($RC)!"
57         kill -HUP $PID
58         exit $RC
59 fi
60
61 echo "Testing for slave slapd..."
62 for i in 0 1 2 3 4 5; do
63         $LDAPSEARCH -s base -b "$MONITOR" -h localhost -p $SLAVEPORT \
64                 'objectclass=*' > /dev/null 2>&1
65         RC=$?
66         if test $RC = 1 ; then
67                 echo "Waiting 5 seconds for slapd to start..."
68                 sleep 5
69         fi
70 done
71
72 cat /dev/null > $SEARCHOUT
73
74 echo "Testing exact searching..."
75 $LDAPSEARCH -C -S "" -b "$BASEDN" -h localhost -p $SLAVEPORT \
76         'sn=jensen' >> $SEARCHOUT 2>&1
77 if test $RC != 0 ; then
78         echo "ldapsearch failed ($RC)!"
79         kill -HUP $PID $SLAVEPID
80         exit $RC
81 fi
82
83 echo "Testing OR searching..."
84 $LDAPSEARCH -C -S "" -b "$BASEDN" -h localhost -p $SLAVEPORT \
85         '(|(objectclass=groupofnames)(sn=jones))' >> $SEARCHOUT 2>&1
86 if test $RC != 0 ; then
87         echo "ldapsearch failed ($RC)!"
88         kill -HUP $PID $SLAVEPID
89         exit $RC
90 fi
91
92 echo "Testing AND matching and ends-with searching..."
93 $LDAPSEARCH -C -S "" -b "$BASEDN" -h localhost -p $SLAVEPORT \
94         '(&(objectclass=groupofnames)(cn=A*))' >> $SEARCHOUT 2>&1
95 if test $RC != 0 ; then
96         echo "ldapsearch failed ($RC)!"
97         kill -HUP $PID $SLAVEPID
98         exit $RC
99 fi
100
101 echo "Testing NOT searching..."
102 $LDAPSEARCH -C -S "" -b "$BASEDN" -h localhost -p $SLAVEPORT \
103         '(!(objectclass=person))' >> $SEARCHOUT 2>&1
104 if test $RC != 0 ; then
105         echo "ldapsearch failed ($RC)!"
106         kill -HUP $PID $SLAVEPID
107         exit $RC
108 fi
109
110 kill -HUP $PID $SLAVEPID
111
112 LDIF=$SEARCHOUTMASTER
113
114 echo "Filtering ldapsearch results..."
115 . $LDIFFILTER < $SEARCHOUT > $SEARCHFLT
116 echo "Filtering original ldif used to create database..."
117 . $LDIFFILTER < $LDIF > $LDIFFLT
118 echo "Comparing filter output..."
119 $CMP $SEARCHFLT $LDIFFLT > $CMPOUT
120
121 if test $? != 0 ; then
122         echo "Comparison failed"
123         exit 1
124 fi
125
126 echo ">>>>> Test succeeded"
127
128
129 exit 0