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