]> git.sur5r.net Git - openldap/blob - tests/scripts/test015-xsearch
ITS#2401 support tests for dynamically loaded backends
[openldap] / tests / scripts / test015-xsearch
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 echo "Cleaning up in $DBDIR..."
15
16 rm -f $DBDIR/[!C]*
17
18 echo "Running slapadd to build slapd database..."
19 . $CONFFILTER $BACKEND $MONITORDB < $MCONF > $ADDCONF
20 $SLAPADD -f $ADDCONF -l $LDIFORDERED
21 RC=$?
22 if test $RC != 0 ; then
23         echo "slapadd failed ($RC)!"
24         exit $RC
25 fi
26
27 echo "Running slapindex to index slapd database..."
28 . $CONFFILTER $BACKEND $MONITORDB < $CONF > $DBCONF
29 $SLAPINDEX -f $DBCONF
30 RC=$?
31 if test $RC != 0 ; then
32         echo "warning: slapindex failed ($RC)"
33         echo "  assuming no indexing support"
34 fi
35
36 echo "Starting slapd on TCP/IP port $PORT..."
37 $SLAPD -f $DBCONF -h $MASTERURI -d $LVL $TIMING > $MASTERLOG 2>&1 &
38 PID=$!
39 if test $WAIT != 0 ; then
40     echo PID $PID
41     read foo
42 fi
43
44 echo "Testing slapd searching..."
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 = 0 ; then
50                 break
51         fi
52         echo "Waiting 5 seconds for slapd to start..."
53         sleep 5
54 done
55
56 if test $RC != 0 ; then
57         echo "ldapsearch failed ($RC)!"
58         kill -HUP $PID
59         exit $RC
60 fi
61
62 cat /dev/null > $SEARCHOUT
63
64 echo "Testing exact searching..."
65 $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT \
66         '(sn:=jensen)' >> $SEARCHOUT 2>&1
67 RC=$?
68 if test $RC != 0 ; then
69         echo "ldapsearch failed ($RC)!"
70         kill -HUP $PID
71         exit $RC
72 fi
73
74 echo "Testing OR searching..."
75 $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT \
76         '(|(givenName=XX*YY*Z)(cn=)(undef=*)(objectclass=groupofnames)(sn:caseExactMatch:=Jones))' >> $SEARCHOUT 2>&1
77 RC=$?
78 if test $RC != 0 ; then
79         echo "ldapsearch failed ($RC)!"
80         kill -HUP $PID
81         exit $RC
82 fi
83
84 echo "Testing AND matching and ends-with searching..."
85 $LDAPSEARCH -S "" -b "ou=groups,$BASEDN" -s one -h $LOCALHOST -p $PORT \
86         '(&(objectclass=groupofnames)(cn=A*))' >> $SEARCHOUT 2>&1
87 RC=$?
88 if test $RC != 0 ; then
89         echo "ldapsearch failed ($RC)!"
90         kill -HUP $PID
91         exit $RC
92 fi
93
94 echo "Testing NOT searching..."
95 $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT \
96         '(!(objectclass=pilotPerson))' >> $SEARCHOUT 2>&1
97 RC=$?
98 if test $RC != 0 ; then
99         echo "ldapsearch failed ($RC)!"
100         kill -HUP $PID
101         exit $RC
102 fi
103
104 echo "Testing objectClass/attributeType inheritance ..."
105 $LDAPSEARCH -M -a never -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT \
106         '(&(objectClass=inetorgperson)(userid=uham))' \
107         "2.5.4.0" "userid" >> $SEARCHOUT 2>&1
108 RC=$?
109 if test $RC != 0 ; then
110         echo "ldapsearch failed ($RC)!"
111         kill -HUP $PID
112         exit $RC
113 fi
114
115 echo "Testing extended RFC2254 searching..."
116 $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT \
117         '(:dn:caseExactMatch:=University of Michigan)' >> $SEARCHOUT 2>&1
118
119 RC=$?
120 if test $RC != 0 ; then
121         echo "ldapsearch failed ($RC)!"
122         kill -HUP $PID
123         exit $RC
124 fi
125
126 echo "Testing values return filter searching..."
127 $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT \
128         -E '!mv=(o=University of Michigan)' \
129         '(o=University of Michigan)' >> $SEARCHOUT 2>&1
130 RC=$?
131 if test $RC != 0 ; then
132         echo "ldapsearch failed ($RC)!"
133         kill -HUP $PID
134         exit $RC
135 fi
136
137
138 kill -HUP $PID
139
140 LDIF=$SEARCHOUTMASTER
141 LDIF2=$SEARCHOUTX
142
143 echo "Filtering ldapsearch results..."
144 . $LDIFFILTER < $SEARCHOUT > $SEARCHFLT
145 echo "Filtering original ldif used to create database..."
146 . $LDIFFILTER < $LDIF > $LDIFFLT
147 . $LDIFFILTER < $LDIF2 >> $LDIFFLT
148 echo "Comparing filter output..."
149 $CMP $SEARCHFLT $LDIFFLT > $CMPOUT
150
151 if test $? != 0 ; then
152         echo "Comparison failed"
153         exit 1
154 fi
155
156 echo ">>>>> Test succeeded"
157
158
159 exit 0