test020-proxycache revision 1.1 1 1.1 lukem #! /bin/sh
2 1.1 lukem # $OpenLDAP: pkg/ldap/tests/scripts/test020-proxycache,v 1.26.2.9 2008/02/11 23:26:51 kurt Exp $
3 1.1 lukem ## This work is part of OpenLDAP Software <http://www.openldap.org/>.
4 1.1 lukem ##
5 1.1 lukem ## Copyright 1998-2008 The OpenLDAP Foundation.
6 1.1 lukem ## All rights reserved.
7 1.1 lukem ##
8 1.1 lukem ## Redistribution and use in source and binary forms, with or without
9 1.1 lukem ## modification, are permitted only as authorized by the OpenLDAP
10 1.1 lukem ## Public License.
11 1.1 lukem ##
12 1.1 lukem ## A copy of this license is available in the file LICENSE in the
13 1.1 lukem ## top-level directory of the distribution or, alternatively, at
14 1.1 lukem ## <http://www.OpenLDAP.org/license.html>.
15 1.1 lukem
16 1.1 lukem CACHETTL="1m"
17 1.1 lukem NCACHETTL="1m"
18 1.1 lukem SCACHETTL="1m"
19 1.1 lukem CACHE_ENTRY_LIMIT=6
20 1.1 lukem
21 1.1 lukem . $SRCDIR/scripts/defines.sh
22 1.1 lukem
23 1.1 lukem if test $PROXYCACHE = pcacheno; then
24 1.1 lukem echo "Proxy cache overlay not available, test skipped"
25 1.1 lukem exit 0
26 1.1 lukem fi
27 1.1 lukem
28 1.1 lukem if test $BACKLDAP = "ldapno" ; then
29 1.1 lukem echo "LDAP backend not available, test skipped"
30 1.1 lukem exit 0
31 1.1 lukem fi
32 1.1 lukem
33 1.1 lukem mkdir -p $TESTDIR $DBDIR1 $DBDIR2
34 1.1 lukem
35 1.1 lukem # Test proxy caching:
36 1.1 lukem # - start master
37 1.1 lukem # - start proxy cache
38 1.1 lukem # - populate master
39 1.1 lukem # - perform first set of searches at the proxy
40 1.1 lukem # - verify cacheability
41 1.1 lukem # - perform second set of searches at the proxy
42 1.1 lukem # - verify answerability
43 1.1 lukem
44 1.1 lukem echo "Starting master slapd on TCP/IP port $PORT1..."
45 1.1 lukem . $CONFFILTER < $CACHEMASTERCONF > $CONF1
46 1.1 lukem $SLAPD -f $CONF1 -h $URI1 -d $LVL > $LOG1 2>&1 &
47 1.1 lukem PID=$!
48 1.1 lukem if test $WAIT != 0 ; then
49 1.1 lukem echo PID $PID
50 1.1 lukem read foo
51 1.1 lukem fi
52 1.1 lukem KILLPIDS="$PID"
53 1.1 lukem
54 1.1 lukem sleep 1
55 1.1 lukem
56 1.1 lukem echo "Using ldapsearch to check that master slapd is running..."
57 1.1 lukem for i in 0 1 2 3 4 5; do
58 1.1 lukem $LDAPSEARCH -s base -b "$MONITOR" -h $LOCALHOST -p $PORT1 \
59 1.1 lukem 'objectclass=*' > /dev/null 2>&1
60 1.1 lukem RC=$?
61 1.1 lukem if test $RC = 0 ; then
62 1.1 lukem break
63 1.1 lukem fi
64 1.1 lukem echo "Waiting 5 seconds for slapd to start..."
65 1.1 lukem sleep 5
66 1.1 lukem done
67 1.1 lukem
68 1.1 lukem if test $RC != 0 ; then
69 1.1 lukem echo "ldapsearch failed ($RC)!"
70 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
71 1.1 lukem exit $RC
72 1.1 lukem fi
73 1.1 lukem
74 1.1 lukem echo "Using ldapadd to populate the master directory..."
75 1.1 lukem $LDAPADD -x -D "$MANAGERDN" -h $LOCALHOST -p $PORT1 -w $PASSWD < \
76 1.1 lukem $LDIFORDERED > /dev/null 2>&1
77 1.1 lukem RC=$?
78 1.1 lukem if test $RC != 0 ; then
79 1.1 lukem echo "ldapadd failed ($RC)!"
80 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
81 1.1 lukem exit $RC
82 1.1 lukem fi
83 1.1 lukem
84 1.1 lukem echo "Starting proxy cache on TCP/IP port $PORT2..."
85 1.1 lukem . $CONFFILTER < $PROXYCACHECONF > $CONF2
86 1.1 lukem $SLAPD -f $CONF2 -h $URI2 -d $LVL -d pcache > $LOG2 2>&1 &
87 1.1 lukem CACHEPID=$!
88 1.1 lukem if test $WAIT != 0 ; then
89 1.1 lukem echo CACHEPID $CACHEPID
90 1.1 lukem read foo
91 1.1 lukem fi
92 1.1 lukem KILLPIDS="$KILLPIDS $CACHEPID"
93 1.1 lukem
94 1.1 lukem sleep 1
95 1.1 lukem
96 1.1 lukem echo "Using ldapsearch to check that proxy slapd is running..."
97 1.1 lukem for i in 0 1 2 3 4 5; do
98 1.1 lukem $LDAPSEARCH -s base -b "$MONITOR" -h $LOCALHOST -p $PORT2 \
99 1.1 lukem 'objectclass=*' > /dev/null 2>&1
100 1.1 lukem RC=$?
101 1.1 lukem if test $RC = 0 ; then
102 1.1 lukem break
103 1.1 lukem fi
104 1.1 lukem echo "Waiting 5 seconds for slapd to start..."
105 1.1 lukem sleep 5
106 1.1 lukem done
107 1.1 lukem
108 1.1 lukem if test $RC != 0 ; then
109 1.1 lukem echo "ldapsearch failed ($RC)!"
110 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
111 1.1 lukem exit $RC
112 1.1 lukem fi
113 1.1 lukem
114 1.1 lukem cat /dev/null > $SEARCHOUT
115 1.1 lukem
116 1.1 lukem echo "Making queries on the proxy cache..."
117 1.1 lukem CNT=0
118 1.1 lukem
119 1.1 lukem CNT=`expr $CNT + 1`
120 1.1 lukem FILTER="(sn=Jon)"
121 1.1 lukem echo "Query $CNT: filter:$FILTER attrs:all (expect nothing)"
122 1.1 lukem echo "# Query $CNT: filter:$FILTER attrs:all (expect nothing)" >> $SEARCHOUT
123 1.1 lukem $LDAPSEARCH -x -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
124 1.1 lukem "$FILTER" >> $SEARCHOUT 2>> $TESTOUT
125 1.1 lukem RC=$?
126 1.1 lukem if test $RC != 0 ; then
127 1.1 lukem echo "ldapsearch failed ($RC)!"
128 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
129 1.1 lukem exit $RC
130 1.1 lukem fi
131 1.1 lukem
132 1.1 lukem # ITS#4491, if debug messages are unavailable, we can't verify the tests.
133 1.1 lukem grep "query template" $LOG2 > /dev/null
134 1.1 lukem RC=$?
135 1.1 lukem if test $RC != 0 ; then
136 1.1 lukem echo "Debug messages unavailable, test aborted..."
137 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS && wait
138 1.1 lukem exit 0
139 1.1 lukem fi
140 1.1 lukem
141 1.1 lukem CNT=`expr $CNT + 1`
142 1.1 lukem FILTER="(|(cn=*Jon*)(sn=Jon*))"
143 1.1 lukem ATTRS="cn sn title uid"
144 1.1 lukem echo "Query $CNT: filter:$FILTER attrs:$ATTRS"
145 1.1 lukem echo "# Query $CNT: filter:$FILTER attrs:$ATTRS" >> $SEARCHOUT
146 1.1 lukem $LDAPSEARCH -x -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
147 1.1 lukem "$FILTER" $ATTRS >> $SEARCHOUT 2>> $TESTOUT
148 1.1 lukem RC=$?
149 1.1 lukem if test $RC != 0 ; then
150 1.1 lukem echo "ldapsearch failed ($RC)!"
151 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
152 1.1 lukem exit $RC
153 1.1 lukem fi
154 1.1 lukem
155 1.1 lukem CNT=`expr $CNT + 1`
156 1.1 lukem FILTER="(sn=Smith*)"
157 1.1 lukem ATTRS="cn sn uid"
158 1.1 lukem echo "Query $CNT: filter:$FILTER attrs:$ATTRS"
159 1.1 lukem echo "# Query $CNT: filter:$FILTER attrs:$ATTRS" >> $SEARCHOUT
160 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
161 1.1 lukem "$FILTER" $ATTRS >> $SEARCHOUT 2>> $TESTOUT
162 1.1 lukem RC=$?
163 1.1 lukem if test $RC != 0 ; then
164 1.1 lukem echo "ldapsearch failed ($RC)!"
165 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
166 1.1 lukem exit $RC
167 1.1 lukem fi
168 1.1 lukem
169 1.1 lukem CNT=`expr $CNT + 1`
170 1.1 lukem FILTER="(sn=Doe*)"
171 1.1 lukem ATTRS="cn sn title uid"
172 1.1 lukem echo "Query $CNT: filter:$FILTER attrs:$ATTRS"
173 1.1 lukem echo "# Query $CNT: filter:$FILTER attrs:$ATTRS" >> $SEARCHOUT
174 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
175 1.1 lukem "$FILTER" $ATTRS >> $SEARCHOUT 2>> $TESTOUT
176 1.1 lukem RC=$?
177 1.1 lukem if test $RC != 0 ; then
178 1.1 lukem echo "ldapsearch failed ($RC)!"
179 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
180 1.1 lukem exit $RC
181 1.1 lukem fi
182 1.1 lukem
183 1.1 lukem CNT=`expr $CNT + 1`
184 1.1 lukem FILTER="(uid=johnd)"
185 1.1 lukem ATTRS="mail postaladdress telephonenumber cn uid"
186 1.1 lukem echo "Query $CNT: filter:$FILTER attrs:$ATTRS"
187 1.1 lukem echo "# Query $CNT: filter:$FILTER attrs:$ATTRS" >> $SEARCHOUT
188 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
189 1.1 lukem "$FILTER" $ATTRS >> $SEARCHOUT 2>> $TESTOUT
190 1.1 lukem RC=$?
191 1.1 lukem if test $RC != 0 ; then
192 1.1 lukem echo "ldapsearch failed ($RC)!"
193 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
194 1.1 lukem exit $RC
195 1.1 lukem fi
196 1.1 lukem
197 1.1 lukem CNT=`expr $CNT + 1`
198 1.1 lukem FILTER="(mail=*@mail.alumni.example.com)"
199 1.1 lukem ATTRS="cn sn title uid"
200 1.1 lukem echo "Query $CNT: filter:$FILTER attrs:$ATTRS"
201 1.1 lukem echo "# Query $CNT: filter:$FILTER attrs:$ATTRS" >> $SEARCHOUT
202 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
203 1.1 lukem "$FILTER" $ATTRS >> $SEARCHOUT 2>> $TESTOUT
204 1.1 lukem RC=$?
205 1.1 lukem if test $RC != 0 ; then
206 1.1 lukem echo "ldapsearch failed ($RC)!"
207 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
208 1.1 lukem exit $RC
209 1.1 lukem fi
210 1.1 lukem
211 1.1 lukem CNT=`expr $CNT + 1`
212 1.1 lukem FILTER="(mail=*)"
213 1.1 lukem ATTRS="cn sn title uid"
214 1.1 lukem echo "Query $CNT: filter:$FILTER attrs:$ATTRS"
215 1.1 lukem echo "# Query $CNT: filter:$FILTER attrs:$ATTRS" >> $SEARCHOUT
216 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
217 1.1 lukem "$FILTER" $ATTRS >> $SEARCHOUT 2>> $TESTOUT
218 1.1 lukem RC=$?
219 1.1 lukem if test $RC != 0 ; then
220 1.1 lukem echo "ldapsearch failed ($RC)!"
221 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
222 1.1 lukem exit $RC
223 1.1 lukem fi
224 1.1 lukem
225 1.1 lukem CNT=`expr $CNT + 1`
226 1.1 lukem FILTER="(mail=*example.com)"
227 1.1 lukem ATTRS="cn sn title uid"
228 1.1 lukem USERDN="cn=Bjorn Jensen,ou=Information Technology Division,ou=People,dc=example,dc=com"
229 1.1 lukem PASSWD="bjorn"
230 1.1 lukem echo "Query $CNT: filter:$FILTER attrs:$ATTRS"
231 1.1 lukem echo "# Query $CNT: filter:$FILTER attrs:$ATTRS" >> $SEARCHOUT
232 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
233 1.1 lukem -D "$USERDN" -w "$PASSWD" \
234 1.1 lukem "$FILTER" $ATTRS >> $SEARCHOUT 2>> $TESTOUT
235 1.1 lukem RC=$?
236 1.1 lukem case $RC in
237 1.1 lukem 0)
238 1.1 lukem echo "ldapsearch should have failed!"
239 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
240 1.1 lukem exit $RC
241 1.1 lukem ;;
242 1.1 lukem 4)
243 1.1 lukem echo "ldapsearch failed ($RC)"
244 1.1 lukem ;;
245 1.1 lukem *)
246 1.1 lukem echo "ldapsearch failed ($RC)!"
247 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
248 1.1 lukem exit $RC
249 1.1 lukem ;;
250 1.1 lukem esac
251 1.1 lukem
252 1.1 lukem CNT=`expr $CNT + 1`
253 1.1 lukem FILTER="(uid=b*)"
254 1.1 lukem ATTRS="mail"
255 1.1 lukem USERDN="cn=Bjorn Jensen,ou=Information Technology Division,ou=People,dc=example,dc=com"
256 1.1 lukem PASSWD="bjorn"
257 1.1 lukem echo "Query $CNT: filter:$FILTER attrs:$ATTRS"
258 1.1 lukem echo "# Query $CNT: filter:$FILTER attrs:$ATTRS" >> $SEARCHOUT
259 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
260 1.1 lukem -D "$USERDN" -w "$PASSWD" \
261 1.1 lukem "$FILTER" $ATTRS >> $SEARCHOUT 2>> $TESTOUT
262 1.1 lukem RC=$?
263 1.1 lukem case $RC in
264 1.1 lukem 0)
265 1.1 lukem echo "ldapsearch should have failed!"
266 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
267 1.1 lukem exit $RC
268 1.1 lukem ;;
269 1.1 lukem 4)
270 1.1 lukem echo "ldapsearch failed ($RC)"
271 1.1 lukem ;;
272 1.1 lukem *)
273 1.1 lukem echo "ldapsearch failed ($RC)!"
274 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
275 1.1 lukem exit $RC
276 1.1 lukem ;;
277 1.1 lukem esac
278 1.1 lukem
279 1.1 lukem FIRST=$CNT
280 1.1 lukem
281 1.1 lukem # queries 2-6,8-9 are cacheable
282 1.1 lukem CACHEABILITY=011111011
283 1.1 lukem grep CACHEABLE $LOG2 | awk '{
284 1.1 lukem if ($2 == "NOT")
285 1.1 lukem printf "Query %d not cacheable\n",NR
286 1.1 lukem else
287 1.1 lukem printf "Query %d cacheable\n",NR
288 1.1 lukem }'
289 1.1 lukem CACHED=`grep CACHEABLE $LOG2 | awk '{
290 1.1 lukem if ($2 == "NOT")
291 1.1 lukem printf "0"
292 1.1 lukem else
293 1.1 lukem printf "1"
294 1.1 lukem }'`
295 1.1 lukem
296 1.1 lukem if test "$CACHEABILITY" = "$CACHED" ; then
297 1.1 lukem echo "Successfully verified cacheability"
298 1.1 lukem else
299 1.1 lukem echo "Error in verifying cacheability"
300 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
301 1.1 lukem exit 1
302 1.1 lukem fi
303 1.1 lukem
304 1.1 lukem CNT=`expr $CNT + 1`
305 1.1 lukem FILTER="(|(cn=*Jones)(sn=Jones))"
306 1.1 lukem ATTRS="cn sn title uid"
307 1.1 lukem echo "Query $CNT: filter:$FILTER attrs:$ATTRS"
308 1.1 lukem echo "# Query $CNT: filter:$FILTER attrs:$ATTRS" >> $SEARCHOUT
309 1.1 lukem $LDAPSEARCH -x -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
310 1.1 lukem "$FILTER" $ATTRS >> $SEARCHOUT 2>> $TESTOUT
311 1.1 lukem RC=$?
312 1.1 lukem if test $RC != 0 ; then
313 1.1 lukem echo "ldapsearch failed ($RC)!"
314 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
315 1.1 lukem exit $RC
316 1.1 lukem fi
317 1.1 lukem
318 1.1 lukem CNT=`expr $CNT + 1`
319 1.1 lukem FILTER="(sn=Smith)"
320 1.1 lukem ATTRS="cn sn title uid"
321 1.1 lukem echo "Query $CNT: filter:$FILTER attrs:$ATTRS"
322 1.1 lukem echo "# Query $CNT: filter:$FILTER attrs:$ATTRS" >> $SEARCHOUT
323 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
324 1.1 lukem "$FILTER" $ATTRS >> $SEARCHOUT 2>> $TESTOUT
325 1.1 lukem RC=$?
326 1.1 lukem if test $RC != 0 ; then
327 1.1 lukem echo "ldapsearch failed ($RC)!"
328 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
329 1.1 lukem exit $RC
330 1.1 lukem fi
331 1.1 lukem
332 1.1 lukem CNT=`expr $CNT + 1`
333 1.1 lukem FILTER="(uid=bjorn)"
334 1.1 lukem ATTRS="mail postaladdress telephonenumber cn uid"
335 1.1 lukem echo "Query $CNT: filter:$FILTER attrs:$ATTRS"
336 1.1 lukem echo "# Query $CNT: filter:$FILTER attrs:$ATTRS" >> $SEARCHOUT
337 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
338 1.1 lukem "$FILTER" $ATTRS >> $SEARCHOUT 2>> $TESTOUT
339 1.1 lukem RC=$?
340 1.1 lukem if test $RC != 0 ; then
341 1.1 lukem echo "ldapsearch failed ($RC)!"
342 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
343 1.1 lukem exit $RC
344 1.1 lukem fi
345 1.1 lukem
346 1.1 lukem CNT=`expr $CNT + 1`
347 1.1 lukem FILTER="(mail=jaj (at] mail.alumni.example.com)"
348 1.1 lukem ATTRS="cn sn title uid"
349 1.1 lukem echo "Query $CNT: filter:$FILTER attrs:$ATTRS"
350 1.1 lukem echo "# Query $CNT: filter:$FILTER attrs:$ATTRS" >> $SEARCHOUT
351 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
352 1.1 lukem "$FILTER" $ATTRS >> $SEARCHOUT 2>> $TESTOUT
353 1.1 lukem RC=$?
354 1.1 lukem
355 1.1 lukem if test $RC != 0 ; then
356 1.1 lukem echo "ldapsearch failed ($RC)!"
357 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
358 1.1 lukem exit $RC
359 1.1 lukem fi
360 1.1 lukem
361 1.1 lukem CNT=`expr $CNT + 1`
362 1.1 lukem FILTER="(mail=*example.com)"
363 1.1 lukem ATTRS="cn sn title uid"
364 1.1 lukem USERDN="cn=Bjorn Jensen,ou=Information Technology Division,ou=People,dc=example,dc=com"
365 1.1 lukem PASSWD="bjorn"
366 1.1 lukem echo "Query $CNT: filter:$FILTER attrs:$ATTRS"
367 1.1 lukem echo "# Query $CNT: filter:$FILTER attrs:$ATTRS" >> $SEARCHOUT
368 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
369 1.1 lukem -D "$USERDN" -w "$PASSWD" \
370 1.1 lukem "$FILTER" $ATTRS >> $SEARCHOUT 2>> $TESTOUT
371 1.1 lukem RC=$?
372 1.1 lukem case $RC in
373 1.1 lukem 0)
374 1.1 lukem echo "ldapsearch should have failed!"
375 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
376 1.1 lukem exit $RC
377 1.1 lukem ;;
378 1.1 lukem 4)
379 1.1 lukem echo "ldapsearch failed ($RC)"
380 1.1 lukem ;;
381 1.1 lukem *)
382 1.1 lukem echo "ldapsearch failed ($RC)!"
383 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
384 1.1 lukem exit $RC
385 1.1 lukem ;;
386 1.1 lukem esac
387 1.1 lukem
388 1.1 lukem CNT=`expr $CNT + 1`
389 1.1 lukem FILTER="(uid=b*)"
390 1.1 lukem ATTRS="mail"
391 1.1 lukem USERDN="cn=Bjorn Jensen,ou=Information Technology Division,ou=People,dc=example,dc=com"
392 1.1 lukem PASSWD="bjorn"
393 1.1 lukem echo "Query $CNT: filter:$FILTER attrs:$ATTRS"
394 1.1 lukem echo "# Query $CNT: filter:$FILTER attrs:$ATTRS" >> $SEARCHOUT
395 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
396 1.1 lukem -D "$USERDN" -w "$PASSWD" \
397 1.1 lukem "$FILTER" $ATTRS >> $SEARCHOUT 2>> $TESTOUT
398 1.1 lukem RC=$?
399 1.1 lukem case $RC in
400 1.1 lukem 0)
401 1.1 lukem echo "ldapsearch should have failed!"
402 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
403 1.1 lukem exit $RC
404 1.1 lukem ;;
405 1.1 lukem 4)
406 1.1 lukem echo "ldapsearch failed ($RC)"
407 1.1 lukem ;;
408 1.1 lukem *)
409 1.1 lukem echo "ldapsearch failed ($RC)!"
410 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
411 1.1 lukem exit $RC
412 1.1 lukem ;;
413 1.1 lukem esac
414 1.1 lukem
415 1.1 lukem #queries 10-12,15 are answerable, 13-14 are not
416 1.1 lukem #actually, 12 would be answerable, but since 8 made mail=*example.com
417 1.1 lukem #not answerable because of sizelimit, queries contained in it are no longer
418 1.1 lukem #answerable as well
419 1.1 lukem ANSWERABILITY=111001
420 1.1 lukem grep ANSWERABLE $LOG2 | awk "BEGIN {FIRST=$FIRST}"'{
421 1.1 lukem if (NR > FIRST) {
422 1.1 lukem if ($2 == "NOT")
423 1.1 lukem printf "Query %d not answerable\n",NR
424 1.1 lukem else
425 1.1 lukem printf "Query %d answerable\n",NR
426 1.1 lukem }
427 1.1 lukem }'
428 1.1 lukem ANSWERED=`grep ANSWERABLE $LOG2 | awk "BEGIN {FIRST=$FIRST}"'{
429 1.1 lukem if (NR > FIRST) {
430 1.1 lukem if ($2 == "NOT")
431 1.1 lukem printf "0"
432 1.1 lukem else
433 1.1 lukem printf "1"
434 1.1 lukem }
435 1.1 lukem }'`
436 1.1 lukem
437 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
438 1.1 lukem
439 1.1 lukem if test "$ANSWERABILITY" = "$ANSWERED" ; then
440 1.1 lukem echo "Successfully verified answerability"
441 1.1 lukem else
442 1.1 lukem echo "Error in verifying answerability"
443 1.1 lukem exit 1
444 1.1 lukem fi
445 1.1 lukem
446 1.1 lukem echo "Filtering ldapsearch results..."
447 1.1 lukem . $LDIFFILTER < $SEARCHOUT > $SEARCHFLT
448 1.1 lukem echo "Filtering original ldif..."
449 1.1 lukem . $LDIFFILTER < $PROXYCACHEOUT > $LDIFFLT
450 1.1 lukem echo "Comparing filter output..."
451 1.1 lukem $CMP $SEARCHFLT $LDIFFLT > $CMPOUT
452 1.1 lukem
453 1.1 lukem if test $? != 0 ; then
454 1.1 lukem echo "Comparison failed"
455 1.1 lukem exit 1
456 1.1 lukem fi
457 1.1 lukem
458 1.1 lukem echo ">>>>> Test succeeded"
459 1.1 lukem
460 1.1 lukem test $KILLSERVERS != no && wait
461 1.1 lukem
462 1.1 lukem exit 0
463