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