xref: /netbsd-src/external/bsd/openldap/dist/tests/scripts/test063-delta-multiprovider (revision e670fd5c413e99c2f6a37901bb21c537fcd322d2)
1*e670fd5cSchristos#! /bin/sh
2*e670fd5cSchristos# $OpenLDAP$
3*e670fd5cSchristos## This work is part of OpenLDAP Software <http://www.openldap.org/>.
4*e670fd5cSchristos##
5*e670fd5cSchristos## Copyright 1998-2021 The OpenLDAP Foundation.
6*e670fd5cSchristos## All rights reserved.
7*e670fd5cSchristos##
8*e670fd5cSchristos## Redistribution and use in source and binary forms, with or without
9*e670fd5cSchristos## modification, are permitted only as authorized by the OpenLDAP
10*e670fd5cSchristos## Public License.
11*e670fd5cSchristos##
12*e670fd5cSchristos## A copy of this license is available in the file LICENSE in the
13*e670fd5cSchristos## top-level directory of the distribution or, alternatively, at
14*e670fd5cSchristos## <http://www.OpenLDAP.org/license.html>.
15*e670fd5cSchristos
16*e670fd5cSchristosecho "running defines.sh"
17*e670fd5cSchristos. $SRCDIR/scripts/defines.sh
18*e670fd5cSchristos
19*e670fd5cSchristosif test $SYNCPROV = syncprovno; then
20*e670fd5cSchristos	echo "Syncrepl provider overlay not available, test skipped"
21*e670fd5cSchristos	exit 0
22*e670fd5cSchristosfi
23*e670fd5cSchristosif test $ACCESSLOG = accesslogno; then
24*e670fd5cSchristos	echo "Accesslog overlay not available, test skipped"
25*e670fd5cSchristos	exit 0
26*e670fd5cSchristosfi
27*e670fd5cSchristos
28*e670fd5cSchristosMPR=${MPR-4}
29*e670fd5cSchristos
30*e670fd5cSchristosXDIR=$TESTDIR/srv
31*e670fd5cSchristosTMP=$TESTDIR/tmp
32*e670fd5cSchristos
33*e670fd5cSchristosmkdir -p $TESTDIR
34*e670fd5cSchristos
35*e670fd5cSchristos$SLAPPASSWD -g -n >$CONFIGPWF
36*e670fd5cSchristos
37*e670fd5cSchristosif test x"$SYNCMODE" = x ; then
38*e670fd5cSchristos	SYNCMODE=rp
39*e670fd5cSchristosfi
40*e670fd5cSchristoscase "$SYNCMODE" in
41*e670fd5cSchristos	ro)
42*e670fd5cSchristos		SYNCTYPE="type=refreshOnly interval=00:00:00:03"
43*e670fd5cSchristos		;;
44*e670fd5cSchristos	rp)
45*e670fd5cSchristos		SYNCTYPE="type=refreshAndPersist interval=00:00:00:03"
46*e670fd5cSchristos		;;
47*e670fd5cSchristos	*)
48*e670fd5cSchristos		echo "unknown sync mode $SYNCMODE"
49*e670fd5cSchristos		exit 1;
50*e670fd5cSchristos		;;
51*e670fd5cSchristosesac
52*e670fd5cSchristos
53*e670fd5cSchristos#
54*e670fd5cSchristos# Test delta-sync mpr
55*e670fd5cSchristos# - start servers
56*e670fd5cSchristos# - configure over ldap
57*e670fd5cSchristos# - populate over ldap
58*e670fd5cSchristos# - configure syncrepl over ldap
59*e670fd5cSchristos# - break replication
60*e670fd5cSchristos# - modify each server separately
61*e670fd5cSchristos# - restore replication
62*e670fd5cSchristos# - compare results
63*e670fd5cSchristos#
64*e670fd5cSchristos
65*e670fd5cSchristosnullExclude=""
66*e670fd5cSchristostest $BACKEND = null && nullExclude="# "
67*e670fd5cSchristos
68*e670fd5cSchristosKILLPIDS=
69*e670fd5cSchristos
70*e670fd5cSchristosecho "Initializing server configurations..."
71*e670fd5cSchristosn=1
72*e670fd5cSchristoswhile [ $n -le $MPR ]; do
73*e670fd5cSchristos
74*e670fd5cSchristosDBDIR=${XDIR}$n/db
75*e670fd5cSchristosCFDIR=${XDIR}$n/slapd.d
76*e670fd5cSchristos
77*e670fd5cSchristosmkdir -p ${XDIR}$n $DBDIR.1 $DBDIR.2 $CFDIR
78*e670fd5cSchristos
79*e670fd5cSchristoscat > $TMP <<EOF
80*e670fd5cSchristosdn: cn=config
81*e670fd5cSchristosobjectClass: olcGlobal
82*e670fd5cSchristoscn: config
83*e670fd5cSchristosEOF
84*e670fd5cSchristos
85*e670fd5cSchristoso=1
86*e670fd5cSchristoswhile [ $o -le $MPR ]; do
87*e670fd5cSchristosPORT=`expr $BASEPORT + $o`
88*e670fd5cSchristosURI="ldap://${LOCALHOST}:$PORT/"
89*e670fd5cSchristosecho "olcServerID: $o $URI" >> $TMP
90*e670fd5cSchristoso=`expr $o + 1`
91*e670fd5cSchristosdone
92*e670fd5cSchristosecho "" >> $TMP
93*e670fd5cSchristos
94*e670fd5cSchristosif [ "$SYNCPROV" = syncprovmod -o "$ACCESSLOG" = accesslogmod ]; then
95*e670fd5cSchristos  cat <<EOF >> $TMP
96*e670fd5cSchristosdn: cn=module,cn=config
97*e670fd5cSchristosobjectClass: olcModuleList
98*e670fd5cSchristoscn: module
99*e670fd5cSchristosolcModulePath: $TESTWD/../servers/slapd/overlays
100*e670fd5cSchristosEOF
101*e670fd5cSchristos  if [ "$SYNCPROV" = syncprovmod ]; then
102*e670fd5cSchristos  echo "olcModuleLoad: syncprov.la" >> $TMP
103*e670fd5cSchristos  fi
104*e670fd5cSchristos  if [ "$ACCESSLOG" = accesslogmod ]; then
105*e670fd5cSchristos  echo "olcModuleLoad: accesslog.la" >> $TMP
106*e670fd5cSchristos  fi
107*e670fd5cSchristos  echo "" >> $TMP
108*e670fd5cSchristosfi
109*e670fd5cSchristos
110*e670fd5cSchristosif [ "$BACKENDTYPE" = mod ]; then
111*e670fd5cSchristoscat <<EOF >> $TMP
112*e670fd5cSchristosdn: cn=module,cn=config
113*e670fd5cSchristosobjectClass: olcModuleList
114*e670fd5cSchristoscn: module
115*e670fd5cSchristosolcModulePath: $TESTWD/../servers/slapd/back-$BACKEND
116*e670fd5cSchristosolcModuleLoad: back_$BACKEND.la
117*e670fd5cSchristos
118*e670fd5cSchristosEOF
119*e670fd5cSchristosfi
120*e670fd5cSchristos
121*e670fd5cSchristosMYURI=`eval echo '$URI'$n`
122*e670fd5cSchristosPROVIDERURI=`eval echo '$URI'$o`
123*e670fd5cSchristosif test $INDEXDB = indexdb ; then
124*e670fd5cSchristosINDEX1="olcDbIndex: objectClass,entryCSN,reqStart,reqDN,reqResult eq"
125*e670fd5cSchristosINDEX2="olcDbIndex: objectClass,entryCSN,entryUUID eq"
126*e670fd5cSchristoselse
127*e670fd5cSchristosINDEX1=
128*e670fd5cSchristosINDEX2=
129*e670fd5cSchristosfi
130*e670fd5cSchristoscat >> $TMP <<EOF
131*e670fd5cSchristosdn: cn=schema,cn=config
132*e670fd5cSchristosobjectclass: olcSchemaconfig
133*e670fd5cSchristoscn: schema
134*e670fd5cSchristos
135*e670fd5cSchristosinclude: file://$ABS_SCHEMADIR/core.ldif
136*e670fd5cSchristos
137*e670fd5cSchristosinclude: file://$ABS_SCHEMADIR/cosine.ldif
138*e670fd5cSchristos
139*e670fd5cSchristosinclude: file://$ABS_SCHEMADIR/inetorgperson.ldif
140*e670fd5cSchristos
141*e670fd5cSchristosinclude: file://$ABS_SCHEMADIR/openldap.ldif
142*e670fd5cSchristos
143*e670fd5cSchristosinclude: file://$ABS_SCHEMADIR/nis.ldif
144*e670fd5cSchristos
145*e670fd5cSchristosdn: olcDatabase={0}config,cn=config
146*e670fd5cSchristosobjectClass: olcDatabaseConfig
147*e670fd5cSchristosolcDatabase: {0}config
148*e670fd5cSchristosolcRootPW:< file://$CONFIGPWF
149*e670fd5cSchristos
150*e670fd5cSchristosdn: olcDatabase={1}$BACKEND,cn=config
151*e670fd5cSchristosobjectClass: olcDatabaseConfig
152*e670fd5cSchristos${nullExclude}objectClass: olc${BACKEND}Config
153*e670fd5cSchristosolcDatabase: {1}$BACKEND
154*e670fd5cSchristosolcSuffix: cn=log
155*e670fd5cSchristos${nullExclude}olcDbDirectory: ${DBDIR}.1
156*e670fd5cSchristosolcRootDN: $MANAGERDN
157*e670fd5cSchristos$INDEX1
158*e670fd5cSchristos
159*e670fd5cSchristosdn: olcOverlay=syncprov,olcDatabase={1}$BACKEND,cn=config
160*e670fd5cSchristosobjectClass: olcOverlayConfig
161*e670fd5cSchristosobjectClass: olcSyncProvConfig
162*e670fd5cSchristosolcOverlay: syncprov
163*e670fd5cSchristosolcSpNoPresent: TRUE
164*e670fd5cSchristosolcSpReloadHint: TRUE
165*e670fd5cSchristos
166*e670fd5cSchristosdn: olcDatabase={2}$BACKEND,cn=config
167*e670fd5cSchristosobjectClass: olcDatabaseConfig
168*e670fd5cSchristos${nullExclude}objectClass: olc${BACKEND}Config
169*e670fd5cSchristosolcDatabase: {2}$BACKEND
170*e670fd5cSchristosolcSuffix: $BASEDN
171*e670fd5cSchristos${nullExclude}olcDbDirectory: ${DBDIR}.2
172*e670fd5cSchristosolcRootDN: $MANAGERDN
173*e670fd5cSchristosolcRootPW: $PASSWD
174*e670fd5cSchristosEOF
175*e670fd5cSchristos
176*e670fd5cSchristoso=1
177*e670fd5cSchristoswhile [ $o -le $MPR ]; do
178*e670fd5cSchristosPORT=`expr $BASEPORT + $o`
179*e670fd5cSchristosURI="ldap://${LOCALHOST}:$PORT/"
180*e670fd5cSchristoscat >>$TMP <<EOF
181*e670fd5cSchristosolcSyncRepl: rid=00$o provider=$URI binddn="$MANAGERDN" bindmethod=simple
182*e670fd5cSchristos  credentials=$PASSWD searchbase="$BASEDN" $SYNCTYPE
183*e670fd5cSchristos  retry="3 +" timeout=3 logbase="cn=log"
184*e670fd5cSchristos  logfilter="(&(objectclass=auditWriteObject)(reqresult=0))"
185*e670fd5cSchristos  syncdata=accesslog
186*e670fd5cSchristosEOF
187*e670fd5cSchristoso=`expr $o + 1`
188*e670fd5cSchristosdone
189*e670fd5cSchristos
190*e670fd5cSchristoscat >> $TMP <<EOF
191*e670fd5cSchristosolcMultiProvider: TRUE
192*e670fd5cSchristos$INDEX2
193*e670fd5cSchristos
194*e670fd5cSchristosdn: olcOverlay=syncprov,olcDatabase={2}$BACKEND,cn=config
195*e670fd5cSchristosobjectClass: olcOverlayConfig
196*e670fd5cSchristosobjectClass: olcSyncProvConfig
197*e670fd5cSchristosolcOverlay: syncprov
198*e670fd5cSchristos
199*e670fd5cSchristosdn: olcOverlay=accesslog,olcDatabase={2}$BACKEND,cn=config
200*e670fd5cSchristosobjectClass: olcOverlayConfig
201*e670fd5cSchristosobjectClass: olcAccessLogConfig
202*e670fd5cSchristosolcOverlay: accesslog
203*e670fd5cSchristosolcAccessLogDB: cn=log
204*e670fd5cSchristosolcAccessLogOps: writes
205*e670fd5cSchristosolcAccessLogSuccess: TRUE
206*e670fd5cSchristos
207*e670fd5cSchristosEOF
208*e670fd5cSchristoscat <<EOF >> $TMP
209*e670fd5cSchristosdn: olcDatabase={3}monitor,cn=config
210*e670fd5cSchristosobjectClass: olcDatabaseConfig
211*e670fd5cSchristosobjectClass: olcmonitorConfig
212*e670fd5cSchristosolcDatabase: {3}monitor
213*e670fd5cSchristos
214*e670fd5cSchristosEOF
215*e670fd5cSchristos
216*e670fd5cSchristos$SLAPADD -F $CFDIR -n 0  -d-1< $TMP > $TESTOUT 2>&1
217*e670fd5cSchristosPORT=`eval echo '$PORT'$n`
218*e670fd5cSchristosecho "Starting server $n on TCP/IP port $PORT..."
219*e670fd5cSchristoscd ${XDIR}${n}
220*e670fd5cSchristosLOG=`eval echo '$LOG'$n`
221*e670fd5cSchristos$SLAPD -F slapd.d -h $MYURI -d $LVL > $LOG 2>&1 &
222*e670fd5cSchristosPID=$!
223*e670fd5cSchristosif test $WAIT != 0 ; then
224*e670fd5cSchristos    echo PID $PID
225*e670fd5cSchristos    read foo
226*e670fd5cSchristosfi
227*e670fd5cSchristosKILLPIDS="$PID $KILLPIDS"
228*e670fd5cSchristoscd $TESTWD
229*e670fd5cSchristos
230*e670fd5cSchristosecho "Using ldapsearch to check that server $n is running..."
231*e670fd5cSchristossleep 1
232*e670fd5cSchristosfor i in 0 1 2 3 4 5; do
233*e670fd5cSchristos	$LDAPSEARCH -s base -b "" -H $MYURI \
234*e670fd5cSchristos		'objectclass=*' > /dev/null 2>&1
235*e670fd5cSchristos	RC=$?
236*e670fd5cSchristos	if test $RC = 0 ; then
237*e670fd5cSchristos		break
238*e670fd5cSchristos	fi
239*e670fd5cSchristos	echo "Waiting 5 seconds for slapd to start..."
240*e670fd5cSchristos	sleep 5
241*e670fd5cSchristosdone
242*e670fd5cSchristos
243*e670fd5cSchristosif test $RC != 0 ; then
244*e670fd5cSchristos	echo "ldapsearch failed ($RC)!"
245*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
246*e670fd5cSchristos	exit $RC
247*e670fd5cSchristosfi
248*e670fd5cSchristos
249*e670fd5cSchristosif [ $n = 1 ]; then
250*e670fd5cSchristosecho "Using ldapadd for context on server 1..."
251*e670fd5cSchristos$LDAPADD -D "$MANAGERDN" -H $URI1 -w $PASSWD -f $LDIFORDEREDCP \
252*e670fd5cSchristos	>> $TESTOUT 2>&1
253*e670fd5cSchristosRC=$?
254*e670fd5cSchristosif test $RC != 0 ; then
255*e670fd5cSchristos	echo "ldapadd failed for server $n database ($RC)!"
256*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
257*e670fd5cSchristos	exit $RC
258*e670fd5cSchristosfi
259*e670fd5cSchristosfi
260*e670fd5cSchristos
261*e670fd5cSchristosn=`expr $n + 1`
262*e670fd5cSchristosdone
263*e670fd5cSchristos
264*e670fd5cSchristosecho "Using ldapadd to populate server 1..."
265*e670fd5cSchristos$LDAPADD -D "$MANAGERDN" -H $URI1 -w $PASSWD -f $LDIFORDEREDNOCP \
266*e670fd5cSchristos	>> $TESTOUT 2>&1
267*e670fd5cSchristosRC=$?
268*e670fd5cSchristosif test $RC != 0 ; then
269*e670fd5cSchristos	echo "ldapadd failed for server $n database ($RC)!"
270*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
271*e670fd5cSchristos	exit $RC
272*e670fd5cSchristosfi
273*e670fd5cSchristos
274*e670fd5cSchristosecho "Waiting $SLEEP1 seconds for syncrepl to receive changes..."
275*e670fd5cSchristossleep $SLEEP1
276*e670fd5cSchristos
277*e670fd5cSchristosn=1
278*e670fd5cSchristoswhile [ $n -le $MPR ]; do
279*e670fd5cSchristosPORT=`expr $BASEPORT + $n`
280*e670fd5cSchristosURI="ldap://${LOCALHOST}:$PORT/"
281*e670fd5cSchristos
282*e670fd5cSchristosecho "Using ldapsearch to read all the entries from server $n..."
283*e670fd5cSchristos$LDAPSEARCH -S "" -b "$BASEDN" -D "$MANAGERDN" -H $URI -w $PASSWD  \
284*e670fd5cSchristos	'objectclass=*' > $TESTDIR/server$n.out 2>&1
285*e670fd5cSchristosRC=$?
286*e670fd5cSchristos
287*e670fd5cSchristosif test $RC != 0 ; then
288*e670fd5cSchristos	echo "ldapsearch failed at server $n ($RC)!"
289*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
290*e670fd5cSchristos	exit $RC
291*e670fd5cSchristosfi
292*e670fd5cSchristos$LDIFFILTER < $TESTDIR/server$n.out > $TESTDIR/server$n.flt
293*e670fd5cSchristosn=`expr $n + 1`
294*e670fd5cSchristosdone
295*e670fd5cSchristos
296*e670fd5cSchristosn=2
297*e670fd5cSchristoswhile [ $n -le $MPR ]; do
298*e670fd5cSchristosecho "Comparing retrieved entries from server 1 and server $n..."
299*e670fd5cSchristos$CMP $PROVIDERFLT $TESTDIR/server$n.flt > $CMPOUT
300*e670fd5cSchristos
301*e670fd5cSchristosif test $? != 0 ; then
302*e670fd5cSchristos	echo "test failed - server 1 and server $n databases differ"
303*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
304*e670fd5cSchristos	exit 1
305*e670fd5cSchristosfi
306*e670fd5cSchristosn=`expr $n + 1`
307*e670fd5cSchristosdone
308*e670fd5cSchristos
309*e670fd5cSchristosecho "Using ldapadd to populate server 2..."
310*e670fd5cSchristoscp $LDIFADD1 $TESTDIR/add.ldif
311*e670fd5cSchristosecho "displayName: The other" >>$TESTDIR/add.ldif
312*e670fd5cSchristos$LDAPADD -D "$MANAGERDN" -H $URI2 -w $PASSWD -f $TESTDIR/add.ldif \
313*e670fd5cSchristos	>> $TESTOUT 2>&1
314*e670fd5cSchristosRC=$?
315*e670fd5cSchristosif test $RC != 0 ; then
316*e670fd5cSchristos	echo "ldapadd failed for server 2 database ($RC)!"
317*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
318*e670fd5cSchristos	exit $RC
319*e670fd5cSchristosfi
320*e670fd5cSchristos
321*e670fd5cSchristosTHEDN="cn=James A Jones 2,ou=Alumni Association,ou=People,dc=example,dc=com"
322*e670fd5cSchristossleep 1
323*e670fd5cSchristosfor i in 1 2 3; do
324*e670fd5cSchristos	$LDAPSEARCH -S "" -b "$THEDN" -H $URI1 \
325*e670fd5cSchristos		-s base '(objectClass=*)' entryCSN > "${PROVIDEROUT}.$i" 2>&1
326*e670fd5cSchristos	RC=$?
327*e670fd5cSchristos
328*e670fd5cSchristos	if test $RC = 0 ; then
329*e670fd5cSchristos		break
330*e670fd5cSchristos	fi
331*e670fd5cSchristos
332*e670fd5cSchristos	if test $RC != 32 ; then
333*e670fd5cSchristos		echo "ldapsearch failed at consumer ($RC)!"
334*e670fd5cSchristos		test $KILLSERVERS != no && kill -HUP $KILLPIDS
335*e670fd5cSchristos		exit $RC
336*e670fd5cSchristos	fi
337*e670fd5cSchristos
338*e670fd5cSchristos	echo "Waiting $SLEEP1 seconds for syncrepl to receive changes..."
339*e670fd5cSchristos	sleep $SLEEP1
340*e670fd5cSchristosdone
341*e670fd5cSchristos
342*e670fd5cSchristosn=1
343*e670fd5cSchristoswhile [ $n -le $MPR ]; do
344*e670fd5cSchristosPORT=`expr $BASEPORT + $n`
345*e670fd5cSchristosURI="ldap://${LOCALHOST}:$PORT/"
346*e670fd5cSchristos
347*e670fd5cSchristosecho "Using ldapsearch to read all the entries from server $n..."
348*e670fd5cSchristos$LDAPSEARCH -S "" -b "$BASEDN" -D "$MANAGERDN" -H $URI -w $PASSWD  \
349*e670fd5cSchristos	'objectclass=*' > $TESTDIR/server$n.out 2>&1
350*e670fd5cSchristosRC=$?
351*e670fd5cSchristos
352*e670fd5cSchristosif test $RC != 0 ; then
353*e670fd5cSchristos	echo "ldapsearch failed at server $n ($RC)!"
354*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
355*e670fd5cSchristos	exit $RC
356*e670fd5cSchristosfi
357*e670fd5cSchristos$LDIFFILTER < $TESTDIR/server$n.out > $TESTDIR/server$n.flt
358*e670fd5cSchristosn=`expr $n + 1`
359*e670fd5cSchristosdone
360*e670fd5cSchristos
361*e670fd5cSchristosn=2
362*e670fd5cSchristoswhile [ $n -le $MPR ]; do
363*e670fd5cSchristosecho "Comparing retrieved entries from server 1 and server $n..."
364*e670fd5cSchristos$CMP $PROVIDERFLT $TESTDIR/server$n.flt > $CMPOUT
365*e670fd5cSchristos
366*e670fd5cSchristosif test $? != 0 ; then
367*e670fd5cSchristos	echo "test failed - server 1 and server $n databases differ"
368*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
369*e670fd5cSchristos	exit 1
370*e670fd5cSchristosfi
371*e670fd5cSchristosn=`expr $n + 1`
372*e670fd5cSchristosdone
373*e670fd5cSchristos
374*e670fd5cSchristosecho "Breaking replication between server 1 and 2..."
375*e670fd5cSchristosn=1
376*e670fd5cSchristoswhile [ $n -le 2 ]; do
377*e670fd5cSchristosMYURI=`eval echo '$URI'$n`
378*e670fd5cSchristoso=`expr $n - 1`
379*e670fd5cSchristos$LDAPMODIFY -D cn=config -H $MYURI -y $CONFIGPWF > $TESTOUT 2>&1 <<EOF
380*e670fd5cSchristosdn: olcDatabase={2}$BACKEND,cn=config
381*e670fd5cSchristoschangetype: modify
382*e670fd5cSchristosdelete: olcSyncRepl
383*e670fd5cSchristos-
384*e670fd5cSchristos
385*e670fd5cSchristosEOF
386*e670fd5cSchristosRC=$?
387*e670fd5cSchristosif test $RC != 0 ; then
388*e670fd5cSchristos	echo "ldapmodify failed for server $n config ($RC)!"
389*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
390*e670fd5cSchristos	exit $RC
391*e670fd5cSchristosfi
392*e670fd5cSchristosn=`expr $n + 1`
393*e670fd5cSchristosdone
394*e670fd5cSchristos
395*e670fd5cSchristosecho "Using ldapmodify to force conflicts between server 1 and 2..."
396*e670fd5cSchristos$LDAPMODIFY -D "$MANAGERDN" -H $URI1 -w $PASSWD \
397*e670fd5cSchristos	>> $TESTOUT 2>&1 << EOF
398*e670fd5cSchristosdn: $THEDN
399*e670fd5cSchristoschangetype: modify
400*e670fd5cSchristosadd: description
401*e670fd5cSchristosdescription: Amazing
402*e670fd5cSchristos-
403*e670fd5cSchristosadd: displayName
404*e670fd5cSchristosdisplayName: James the Second
405*e670fd5cSchristos-
406*e670fd5cSchristosdelete: displayName
407*e670fd5cSchristosdisplayName: The other
408*e670fd5cSchristos
409*e670fd5cSchristosEOF
410*e670fd5cSchristosRC=$?
411*e670fd5cSchristosif test $RC != 0 ; then
412*e670fd5cSchristos	echo "ldapmodify failed for server 1 database ($RC)!"
413*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
414*e670fd5cSchristos	exit $RC
415*e670fd5cSchristosfi
416*e670fd5cSchristos
417*e670fd5cSchristos$LDAPMODIFY -D "$MANAGERDN" -H $URI2 -w $PASSWD \
418*e670fd5cSchristos	>> $TESTOUT 2>&1 << EOF
419*e670fd5cSchristosdn: $THEDN
420*e670fd5cSchristoschangetype: modify
421*e670fd5cSchristosreplace: employeetype
422*e670fd5cSchristos-
423*e670fd5cSchristosadd: description
424*e670fd5cSchristosdescription: Stupendous
425*e670fd5cSchristos-
426*e670fd5cSchristosadd: displayName
427*e670fd5cSchristosdisplayName: James II
428*e670fd5cSchristos-
429*e670fd5cSchristosdelete: displayName
430*e670fd5cSchristosdisplayName: The other
431*e670fd5cSchristos
432*e670fd5cSchristosEOF
433*e670fd5cSchristosRC=$?
434*e670fd5cSchristosif test $RC != 0 ; then
435*e670fd5cSchristos	echo "ldapmodify failed for server 2 database ($RC)!"
436*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
437*e670fd5cSchristos	exit $RC
438*e670fd5cSchristosfi
439*e670fd5cSchristos
440*e670fd5cSchristos$LDAPMODIFY -D "$MANAGERDN" -H $URI1 -w $PASSWD \
441*e670fd5cSchristos	>> $TESTOUT 2>&1 << EOF
442*e670fd5cSchristosdn: $THEDN
443*e670fd5cSchristoschangetype: modify
444*e670fd5cSchristosdelete: description
445*e670fd5cSchristosdescription: Outstanding
446*e670fd5cSchristos-
447*e670fd5cSchristosadd: description
448*e670fd5cSchristosdescription: Mindboggling
449*e670fd5cSchristos
450*e670fd5cSchristosEOF
451*e670fd5cSchristosRC=$?
452*e670fd5cSchristosif test $RC != 0 ; then
453*e670fd5cSchristos	echo "ldapmodify failed for server 1 database ($RC)!"
454*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
455*e670fd5cSchristos	exit $RC
456*e670fd5cSchristosfi
457*e670fd5cSchristos
458*e670fd5cSchristos$LDAPMODIFY -D "$MANAGERDN" -H $URI2 -w $PASSWD \
459*e670fd5cSchristos	>> $TESTOUT 2>&1 << EOF
460*e670fd5cSchristosdn: $THEDN
461*e670fd5cSchristoschangetype: modify
462*e670fd5cSchristosdelete: description
463*e670fd5cSchristosdescription: OutStanding
464*e670fd5cSchristos-
465*e670fd5cSchristosadd: description
466*e670fd5cSchristosdescription: Bizarre
467*e670fd5cSchristos
468*e670fd5cSchristosEOF
469*e670fd5cSchristosRC=$?
470*e670fd5cSchristosif test $RC != 0 ; then
471*e670fd5cSchristos	echo "ldapmodify failed for server 2 database ($RC)!"
472*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
473*e670fd5cSchristos	exit $RC
474*e670fd5cSchristosfi
475*e670fd5cSchristos
476*e670fd5cSchristos$LDAPMODIFY -D "$MANAGERDN" -H $URI1 -w $PASSWD \
477*e670fd5cSchristos	>> $TESTOUT 2>&1 << EOF
478*e670fd5cSchristosdn: $THEDN
479*e670fd5cSchristoschangetype: modify
480*e670fd5cSchristosadd: carLicense
481*e670fd5cSchristoscarLicense: 123-XYZ
482*e670fd5cSchristos-
483*e670fd5cSchristosadd: employeeNumber
484*e670fd5cSchristosemployeeNumber: 32
485*e670fd5cSchristos
486*e670fd5cSchristosEOF
487*e670fd5cSchristosRC=$?
488*e670fd5cSchristosif test $RC != 0 ; then
489*e670fd5cSchristos	echo "ldapmodify failed for server 1 database ($RC)!"
490*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
491*e670fd5cSchristos	exit $RC
492*e670fd5cSchristosfi
493*e670fd5cSchristos
494*e670fd5cSchristos$LDAPMODIFY -D "$MANAGERDN" -H $URI2 -w $PASSWD \
495*e670fd5cSchristos	>> $TESTOUT 2>&1 << EOF
496*e670fd5cSchristosdn: $THEDN
497*e670fd5cSchristoschangetype: modify
498*e670fd5cSchristosadd: employeeType
499*e670fd5cSchristosemployeeType: deadwood
500*e670fd5cSchristos-
501*e670fd5cSchristosadd: employeeNumber
502*e670fd5cSchristosemployeeNumber: 64
503*e670fd5cSchristos
504*e670fd5cSchristosEOF
505*e670fd5cSchristosRC=$?
506*e670fd5cSchristosif test $RC != 0 ; then
507*e670fd5cSchristos	echo "ldapmodify failed for server 2 database ($RC)!"
508*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
509*e670fd5cSchristos	exit $RC
510*e670fd5cSchristosfi
511*e670fd5cSchristos
512*e670fd5cSchristos$LDAPMODIFY -D "$MANAGERDN" -H $URI1 -w $PASSWD \
513*e670fd5cSchristos	>> $TESTOUT 2>&1 << EOF
514*e670fd5cSchristosdn: $THEDN
515*e670fd5cSchristoschangetype: modify
516*e670fd5cSchristosreplace: sn
517*e670fd5cSchristossn: Replaced later
518*e670fd5cSchristos-
519*e670fd5cSchristosreplace: sn
520*e670fd5cSchristossn: Surname
521*e670fd5cSchristosEOF
522*e670fd5cSchristosRC=$?
523*e670fd5cSchristosif test $RC != 0 ; then
524*e670fd5cSchristos	echo "ldapmodify failed for server 1 database ($RC)!"
525*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
526*e670fd5cSchristos	exit $RC
527*e670fd5cSchristosfi
528*e670fd5cSchristos
529*e670fd5cSchristosecho "Restoring replication between server 1 and 2..."
530*e670fd5cSchristoscat > $TMP <<EOF
531*e670fd5cSchristosdn: olcDatabase={2}$BACKEND,cn=config
532*e670fd5cSchristoschangetype: modify
533*e670fd5cSchristosadd: olcSyncRepl
534*e670fd5cSchristosEOF
535*e670fd5cSchristosn=1
536*e670fd5cSchristoswhile [ $n -le $MPR ]; do
537*e670fd5cSchristosMYURI=`eval echo '$URI'$n`
538*e670fd5cSchristosPROVIDERURI=`eval echo '$URI'$n`
539*e670fd5cSchristoscat >> $TMP <<EOF
540*e670fd5cSchristosolcSyncRepl: rid=00$n provider=$PROVIDERURI binddn="$MANAGERDN" bindmethod=simple
541*e670fd5cSchristos  credentials=$PASSWD searchbase="$BASEDN" $SYNCTYPE
542*e670fd5cSchristos  retry="3 +" timeout=3 logbase="cn=log"
543*e670fd5cSchristos  logfilter="(&(objectclass=auditWriteObject)(reqresult=0))"
544*e670fd5cSchristos  syncdata=accesslog
545*e670fd5cSchristosEOF
546*e670fd5cSchristosn=`expr $n + 1`
547*e670fd5cSchristosdone
548*e670fd5cSchristoscat >> $TMP <<EOF
549*e670fd5cSchristos-
550*e670fd5cSchristosreplace: olcMultiProvider
551*e670fd5cSchristosolcMultiProvider: TRUE
552*e670fd5cSchristosEOF
553*e670fd5cSchristosn=1
554*e670fd5cSchristoswhile [ $n -le 2 ]; do
555*e670fd5cSchristosMYURI=`eval echo '$URI'$n`
556*e670fd5cSchristos$LDAPMODIFY -D cn=config -H $MYURI -y $CONFIGPWF > $TESTOUT 2>&1 <$TMP
557*e670fd5cSchristosRC=$?
558*e670fd5cSchristosif test $RC != 0 ; then
559*e670fd5cSchristos	echo "ldapmodify failed for server $n config ($RC)!"
560*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
561*e670fd5cSchristos	exit $RC
562*e670fd5cSchristosfi
563*e670fd5cSchristosn=`expr $n + 1`
564*e670fd5cSchristosdone
565*e670fd5cSchristos
566*e670fd5cSchristosecho "Waiting $SLEEP1 seconds for syncrepl to receive changes..."
567*e670fd5cSchristossleep $SLEEP1
568*e670fd5cSchristos
569*e670fd5cSchristosn=1
570*e670fd5cSchristoswhile [ $n -le $MPR ]; do
571*e670fd5cSchristosPORT=`expr $BASEPORT + $n`
572*e670fd5cSchristosURI="ldap://${LOCALHOST}:$PORT/"
573*e670fd5cSchristos
574*e670fd5cSchristosecho "Using ldapsearch to read all the entries from server $n..."
575*e670fd5cSchristos$LDAPSEARCH -S "" -b "$BASEDN" -D "$MANAGERDN" -H $URI -w $PASSWD  \
576*e670fd5cSchristos	'objectclass=*' > $TESTDIR/server$n.out 2>&1
577*e670fd5cSchristosRC=$?
578*e670fd5cSchristos
579*e670fd5cSchristosif test $RC != 0 ; then
580*e670fd5cSchristos	echo "ldapsearch failed at server $n ($RC)!"
581*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
582*e670fd5cSchristos	exit $RC
583*e670fd5cSchristosfi
584*e670fd5cSchristos$LDIFFILTER -s a < $TESTDIR/server$n.out > $TESTDIR/server$n.flt
585*e670fd5cSchristosn=`expr $n + 1`
586*e670fd5cSchristosdone
587*e670fd5cSchristos
588*e670fd5cSchristosn=2
589*e670fd5cSchristoswhile [ $n -le $MPR ]; do
590*e670fd5cSchristosecho "Comparing retrieved entries from server 1 and server $n..."
591*e670fd5cSchristos$CMP $PROVIDERFLT $TESTDIR/server$n.flt > $CMPOUT
592*e670fd5cSchristos
593*e670fd5cSchristosif test $? != 0 ; then
594*e670fd5cSchristos	echo "test failed - server 1 and server $n databases differ"
595*e670fd5cSchristos	test $KILLSERVERS != no && kill -HUP $KILLPIDS
596*e670fd5cSchristos	exit 1
597*e670fd5cSchristosfi
598*e670fd5cSchristosn=`expr $n + 1`
599*e670fd5cSchristosdone
600*e670fd5cSchristos
601*e670fd5cSchristostest $KILLSERVERS != no && kill -HUP $KILLPIDS
602*e670fd5cSchristos
603*e670fd5cSchristosecho ">>>>> Test succeeded"
604*e670fd5cSchristos
605*e670fd5cSchristostest $KILLSERVERS != no && wait
606*e670fd5cSchristos
607*e670fd5cSchristosexit 0
608