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