test043-delta-syncrepl revision 1.1.1.4.10.1 1 1.1 lukem #! /bin/sh
2 1.1.1.4 tron # $OpenLDAP$
3 1.1 lukem ## This work is part of OpenLDAP Software <http://www.openldap.org/>.
4 1.1 lukem ##
5 1.1.1.4.10.1 bouyer ## Copyright 1998-2016 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 echo "running defines.sh"
17 1.1 lukem . $SRCDIR/scripts/defines.sh
18 1.1 lukem
19 1.1 lukem if test $SYNCPROV = syncprovno; then
20 1.1 lukem echo "Syncrepl provider overlay not available, test skipped"
21 1.1 lukem exit 0
22 1.1 lukem fi
23 1.1 lukem if test $ACCESSLOG = accesslogno; then
24 1.1 lukem echo "Accesslog overlay not available, test skipped"
25 1.1 lukem exit 0
26 1.1 lukem fi
27 1.1.1.3 adam if test $BACKEND = ldif ; then
28 1.1.1.3 adam # Onelevel search does not return entries in order of creation or CSN.
29 1.1.1.3 adam echo "$BACKEND backend unsuitable for syncprov logdb, test skipped"
30 1.1.1.3 adam exit 0
31 1.1.1.3 adam fi
32 1.1 lukem
33 1.1 lukem mkdir -p $TESTDIR $DBDIR1A $DBDIR1B $DBDIR2
34 1.1 lukem
35 1.1.1.4.10.1 bouyer SPEC="mdb=a,bdb=a,hdb=a"
36 1.1.1.4.10.1 bouyer
37 1.1 lukem #
38 1.1 lukem # Test replication:
39 1.1.1.4 tron # - start provider
40 1.1 lukem # - start consumer
41 1.1 lukem # - populate over ldap
42 1.1 lukem # - perform some modifies and deleted
43 1.1 lukem # - attempt to modify the consumer (referral or chain)
44 1.1 lukem # - retrieve database over ldap and compare against expected results
45 1.1 lukem #
46 1.1 lukem
47 1.1.1.4 tron echo "Starting provider slapd on TCP/IP port $PORT1..."
48 1.1 lukem . $CONFFILTER $BACKEND $MONITORDB < $DSRMASTERCONF > $CONF1
49 1.1 lukem $SLAPD -f $CONF1 -h $URI1 -d $LVL $TIMING > $LOG1 2>&1 &
50 1.1 lukem PID=$!
51 1.1 lukem if test $WAIT != 0 ; then
52 1.1 lukem echo PID $PID
53 1.1 lukem read foo
54 1.1 lukem fi
55 1.1 lukem KILLPIDS="$PID"
56 1.1 lukem
57 1.1 lukem sleep 1
58 1.1 lukem
59 1.1.1.4 tron echo "Using ldapsearch to check that provider slapd is running..."
60 1.1 lukem for i in 0 1 2 3 4 5; do
61 1.1 lukem $LDAPSEARCH -s base -b "$MONITOR" -h $LOCALHOST -p $PORT1 \
62 1.1 lukem 'objectclass=*' > /dev/null 2>&1
63 1.1 lukem RC=$?
64 1.1 lukem if test $RC = 0 ; then
65 1.1 lukem break
66 1.1 lukem fi
67 1.1 lukem echo "Waiting 5 seconds for slapd to start..."
68 1.1 lukem sleep 5
69 1.1 lukem done
70 1.1 lukem
71 1.1 lukem if test $RC != 0 ; then
72 1.1 lukem echo "ldapsearch failed ($RC)!"
73 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
74 1.1 lukem exit $RC
75 1.1 lukem fi
76 1.1 lukem
77 1.1.1.4 tron echo "Using ldapadd to create the context prefix entries in the provider..."
78 1.1 lukem $LDAPADD -D "$MANAGERDN" -h $LOCALHOST -p $PORT1 -w $PASSWD < \
79 1.1 lukem $LDIFORDEREDCP > /dev/null 2>&1
80 1.1 lukem RC=$?
81 1.1 lukem if test $RC != 0 ; then
82 1.1 lukem echo "ldapadd failed ($RC)!"
83 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
84 1.1 lukem exit $RC
85 1.1 lukem fi
86 1.1 lukem
87 1.1 lukem echo "Starting consumer slapd on TCP/IP port $PORT2..."
88 1.1 lukem . $CONFFILTER $BACKEND $MONITORDB < $DSRSLAVECONF > $CONF2
89 1.1 lukem $SLAPD -f $CONF2 -h $URI2 -d $LVL $TIMING > $LOG2 2>&1 &
90 1.1 lukem SLAVEPID=$!
91 1.1 lukem if test $WAIT != 0 ; then
92 1.1 lukem echo SLAVEPID $SLAVEPID
93 1.1 lukem read foo
94 1.1 lukem fi
95 1.1 lukem KILLPIDS="$KILLPIDS $SLAVEPID"
96 1.1 lukem
97 1.1 lukem sleep 1
98 1.1 lukem
99 1.1 lukem echo "Using ldapsearch to check that consumer slapd is running..."
100 1.1 lukem for i in 0 1 2 3 4 5; do
101 1.1 lukem $LDAPSEARCH -s base -b "$MONITOR" -h $LOCALHOST -p $PORT2 \
102 1.1 lukem 'objectclass=*' > /dev/null 2>&1
103 1.1 lukem RC=$?
104 1.1 lukem if test $RC = 0 ; then
105 1.1 lukem break
106 1.1 lukem fi
107 1.1 lukem echo "Waiting 5 seconds for slapd to start..."
108 1.1 lukem sleep 5
109 1.1 lukem done
110 1.1 lukem
111 1.1 lukem if test $RC != 0 ; then
112 1.1 lukem echo "ldapsearch failed ($RC)!"
113 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
114 1.1 lukem exit $RC
115 1.1 lukem fi
116 1.1 lukem
117 1.1.1.4 tron echo "Using ldapadd to populate the provider directory..."
118 1.1 lukem $LDAPADD -D "$MANAGERDN" -h $LOCALHOST -p $PORT1 -w $PASSWD < \
119 1.1 lukem $LDIFORDEREDNOCP > /dev/null 2>&1
120 1.1 lukem RC=$?
121 1.1 lukem if test $RC != 0 ; then
122 1.1 lukem echo "ldapadd failed ($RC)!"
123 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
124 1.1 lukem exit $RC
125 1.1 lukem fi
126 1.1 lukem
127 1.1.1.2 lukem echo "Waiting $SLEEP1 seconds for syncrepl to receive changes..."
128 1.1.1.2 lukem sleep $SLEEP1
129 1.1 lukem
130 1.1 lukem echo "Stopping the provider, sleeping 10 seconds and restarting it..."
131 1.1 lukem kill -HUP "$PID"
132 1.1 lukem sleep 10
133 1.1 lukem echo "RESTART" >> $LOG1
134 1.1 lukem $SLAPD -f $CONF1 -h $URI1 -d $LVL $TIMING >> $LOG1 2>&1 &
135 1.1 lukem PID=$!
136 1.1 lukem if test $WAIT != 0 ; then
137 1.1 lukem echo PID $PID
138 1.1 lukem read foo
139 1.1 lukem fi
140 1.1 lukem KILLPIDS="$PID $SLAVEPID"
141 1.1 lukem
142 1.1 lukem sleep 1
143 1.1 lukem
144 1.1.1.4 tron echo "Using ldapsearch to check that provider slapd is running..."
145 1.1 lukem for i in 0 1 2 3 4 5; do
146 1.1 lukem $LDAPSEARCH -s base -b "$MONITOR" -h $LOCALHOST -p $PORT1 \
147 1.1 lukem 'objectclass=*' > /dev/null 2>&1
148 1.1 lukem RC=$?
149 1.1 lukem if test $RC = 0 ; then
150 1.1 lukem break
151 1.1 lukem fi
152 1.1 lukem echo "Waiting 5 seconds for slapd to start..."
153 1.1 lukem sleep 5
154 1.1 lukem done
155 1.1 lukem
156 1.1 lukem if test $RC != 0 ; then
157 1.1 lukem echo "ldapsearch failed ($RC)!"
158 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
159 1.1 lukem exit $RC
160 1.1 lukem fi
161 1.1 lukem
162 1.1.1.4 tron echo "Using ldapmodify to modify provider directory..."
163 1.1 lukem
164 1.1 lukem #
165 1.1 lukem # Do some modifications
166 1.1 lukem #
167 1.1 lukem
168 1.1 lukem $LDAPMODIFY -v -D "$MANAGERDN" -h $LOCALHOST -p $PORT1 -w $PASSWD > \
169 1.1 lukem $TESTOUT 2>&1 << EOMODS
170 1.1 lukem dn: cn=James A Jones 1, ou=Alumni Association, ou=People, dc=example,dc=com
171 1.1 lukem changetype: modify
172 1.1 lukem add: drink
173 1.1 lukem drink: Orange Juice
174 1.1 lukem -
175 1.1 lukem delete: sn
176 1.1 lukem sn: Jones
177 1.1 lukem -
178 1.1 lukem add: sn
179 1.1 lukem sn: Jones
180 1.1 lukem
181 1.1 lukem dn: cn=Bjorn Jensen, ou=Information Technology Division, ou=People, dc=example,dc=com
182 1.1 lukem changetype: modify
183 1.1 lukem replace: drink
184 1.1 lukem drink: Iced Tea
185 1.1 lukem
186 1.1 lukem dn: cn=ITD Staff,ou=Groups,dc=example,dc=com
187 1.1 lukem changetype: modify
188 1.1 lukem delete: uniquemember
189 1.1 lukem uniquemember: cn=James A Jones 2, ou=Information Technology Division, ou=People, dc=example,dc=com
190 1.1 lukem uniquemember: cn=Bjorn Jensen, ou=Information Technology Division, ou=People, dc=example,dc=com
191 1.1 lukem -
192 1.1 lukem add: uniquemember
193 1.1 lukem uniquemember: cn=Dorothy Stevens, ou=Alumni Association, ou=People, dc=example,dc=com
194 1.1 lukem uniquemember: cn=James A Jones 1, ou=Alumni Association, ou=People, dc=example,dc=com
195 1.1 lukem
196 1.1 lukem dn: cn=All Staff,ou=Groups,dc=example,dc=com
197 1.1 lukem changetype: modify
198 1.1 lukem delete: description
199 1.1 lukem
200 1.1 lukem dn: cn=Gern Jensen, ou=Information Technology Division, ou=People, dc=example,dc=com
201 1.1 lukem changetype: add
202 1.1 lukem objectclass: OpenLDAPperson
203 1.1 lukem cn: Gern Jensen
204 1.1 lukem sn: Jensen
205 1.1 lukem uid: gjensen
206 1.1 lukem title: Chief Investigator, ITD
207 1.1 lukem postaladdress: ITD $ 535 W. William St $ Ann Arbor, MI 48103
208 1.1 lukem seealso: cn=All Staff, ou=Groups, dc=example,dc=com
209 1.1 lukem drink: Coffee
210 1.1 lukem homepostaladdress: 844 Brown St. Apt. 4 $ Ann Arbor, MI 48104
211 1.1 lukem description: Very odd
212 1.1 lukem facsimiletelephonenumber: +1 313 555 7557
213 1.1 lukem telephonenumber: +1 313 555 8343
214 1.1 lukem mail: gjensen@mailgw.example.com
215 1.1 lukem homephone: +1 313 555 8844
216 1.1 lukem
217 1.1 lukem dn: ou=Retired, ou=People, dc=example,dc=com
218 1.1 lukem changetype: add
219 1.1 lukem objectclass: organizationalUnit
220 1.1 lukem ou: Retired
221 1.1 lukem
222 1.1 lukem dn: cn=Rosco P. Coltrane, ou=Information Technology Division, ou=People, dc=example,dc=com
223 1.1 lukem changetype: add
224 1.1 lukem objectclass: OpenLDAPperson
225 1.1 lukem cn: Rosco P. Coltrane
226 1.1 lukem sn: Coltrane
227 1.1 lukem uid: rosco
228 1.1 lukem description: Fat tycoon
229 1.1 lukem
230 1.1 lukem dn: cn=Rosco P. Coltrane, ou=Information Technology Division, ou=People, dc=example,dc=com
231 1.1 lukem changetype: modrdn
232 1.1 lukem newrdn: cn=Rosco P. Coltrane
233 1.1 lukem deleteoldrdn: 1
234 1.1 lukem newsuperior: ou=Retired, ou=People, dc=example,dc=com
235 1.1 lukem
236 1.1 lukem dn: cn=James A Jones 2, ou=Information Technology Division, ou=People, dc=example,dc=com
237 1.1 lukem changetype: delete
238 1.1 lukem
239 1.1 lukem EOMODS
240 1.1 lukem RC=$?
241 1.1 lukem if test $RC != 0 ; then
242 1.1 lukem echo "ldapmodify failed ($RC)!"
243 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
244 1.1 lukem exit $RC
245 1.1 lukem fi
246 1.1 lukem
247 1.1.1.2 lukem echo "Waiting $SLEEP1 seconds for syncrepl to receive changes..."
248 1.1.1.2 lukem sleep $SLEEP1
249 1.1 lukem
250 1.1.1.4 tron echo "Using ldapsearch to read all the entries from the provider..."
251 1.1.1.4 tron $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT1 \
252 1.1.1.4 tron 'objectclass=*' \* + > $MASTEROUT 2>&1
253 1.1.1.4 tron RC=$?
254 1.1.1.4 tron
255 1.1.1.4 tron if test $RC != 0 ; then
256 1.1.1.4 tron echo "ldapsearch failed at provider ($RC)!"
257 1.1.1.4 tron test $KILLSERVERS != no && kill -HUP $KILLPIDS
258 1.1.1.4 tron exit $RC
259 1.1.1.4 tron fi
260 1.1.1.4 tron
261 1.1.1.4 tron echo "Using ldapsearch to read all the entries from the consumer..."
262 1.1.1.4 tron $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
263 1.1.1.4 tron 'objectclass=*' \* + > $SLAVEOUT 2>&1
264 1.1.1.4 tron RC=$?
265 1.1.1.4 tron
266 1.1.1.4 tron if test $RC != 0 ; then
267 1.1.1.4 tron echo "ldapsearch failed at consumer ($RC)!"
268 1.1.1.4 tron test $KILLSERVERS != no && kill -HUP $KILLPIDS
269 1.1.1.4 tron exit $RC
270 1.1.1.4 tron fi
271 1.1.1.4 tron
272 1.1.1.4 tron echo "Filtering provider results..."
273 1.1.1.4.10.1 bouyer $LDIFFILTER -b $BACKEND -s $SPEC < $MASTEROUT | grep -iv "^auditcontext:" > $MASTERFLT
274 1.1.1.4 tron echo "Filtering consumer results..."
275 1.1.1.4.10.1 bouyer $LDIFFILTER -b $BACKEND -s $SPEC < $SLAVEOUT | grep -iv "^auditcontext:" > $SLAVEFLT
276 1.1.1.4 tron
277 1.1.1.4 tron echo "Comparing retrieved entries from provider and consumer..."
278 1.1.1.4 tron $CMP $MASTERFLT $SLAVEFLT > $CMPOUT
279 1.1.1.4 tron
280 1.1.1.4 tron if test $? != 0 ; then
281 1.1.1.4 tron echo "test failed - provider and consumer databases differ"
282 1.1.1.4 tron test $KILLSERVERS != no && kill -HUP $KILLPIDS
283 1.1.1.4 tron exit 1
284 1.1.1.4 tron fi
285 1.1.1.4 tron
286 1.1 lukem echo "Stopping consumer to test recovery..."
287 1.1 lukem kill -HUP $SLAVEPID
288 1.1 lukem sleep 10
289 1.1 lukem
290 1.1.1.4 tron echo "Modifying more entries on the provider..."
291 1.1 lukem $LDAPMODIFY -v -D "$BJORNSDN" -h $LOCALHOST -p $PORT1 -w bjorn >> \
292 1.1 lukem $TESTOUT 2>&1 << EOMODS
293 1.1 lukem dn: cn=Rosco P. Coltrane, ou=Retired, ou=People, dc=example,dc=com
294 1.1 lukem changetype: delete
295 1.1 lukem
296 1.1 lukem dn: cn=Bjorn Jensen, ou=Information Technology Division, ou=People, dc=example,dc=com
297 1.1 lukem changetype: modify
298 1.1 lukem add: drink
299 1.1 lukem drink: Mad Dog 20/20
300 1.1 lukem
301 1.1 lukem dn: cn=Rosco P. Coltrane, ou=Retired, ou=People, dc=example,dc=com
302 1.1 lukem changetype: add
303 1.1 lukem objectclass: OpenLDAPperson
304 1.1 lukem sn: Coltrane
305 1.1 lukem uid: rosco
306 1.1 lukem cn: Rosco P. Coltrane
307 1.1 lukem
308 1.1 lukem dn: cn=Mark Elliot,ou=Alumni Association,ou=People,dc=example,dc=com
309 1.1 lukem changetype: modify
310 1.1 lukem replace: drink
311 1.1 lukem
312 1.1 lukem dn: cn=All Staff,ou=Groups,dc=example,dc=com
313 1.1 lukem changetype: modrdn
314 1.1 lukem newrdn: cn=Some Staff
315 1.1 lukem deleteoldrdn: 1
316 1.1 lukem
317 1.1 lukem EOMODS
318 1.1 lukem
319 1.1 lukem echo "Restarting consumer..."
320 1.1 lukem echo "RESTART" >> $LOG2
321 1.1 lukem $SLAPD -f $CONF2 -h $URI2 -d $LVL $TIMING >> $LOG2 2>&1 &
322 1.1 lukem SLAVEPID=$!
323 1.1 lukem if test $WAIT != 0 ; then
324 1.1 lukem echo SLAVEPID $SLAVEPID
325 1.1 lukem read foo
326 1.1 lukem fi
327 1.1 lukem KILLPIDS="$PID $SLAVEPID"
328 1.1 lukem
329 1.1.1.2 lukem echo "Waiting $SLEEP1 seconds for syncrepl to receive changes..."
330 1.1.1.2 lukem sleep $SLEEP1
331 1.1 lukem
332 1.1 lukem if test ! $BACKLDAP = "ldapno" ; then
333 1.1 lukem echo "Try updating the consumer slapd..."
334 1.1 lukem $LDAPMODIFY -v -D "$MANAGERDN" -h $LOCALHOST -p $PORT2 -w $PASSWD > \
335 1.1 lukem $TESTOUT 2>&1 << EOMODS
336 1.1 lukem dn: cn=James A Jones 1, ou=Alumni Association, ou=People, dc=example, dc=com
337 1.1 lukem changetype: modify
338 1.1 lukem add: description
339 1.1 lukem description: This write must fail because directed to a shadow context,
340 1.1 lukem description: unless the chain overlay is configured appropriately ;)
341 1.1 lukem
342 1.1 lukem EOMODS
343 1.1 lukem
344 1.1 lukem RC=$?
345 1.1 lukem if test $RC != 0 ; then
346 1.1 lukem echo "ldapmodify failed ($RC)!"
347 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
348 1.1 lukem exit $RC
349 1.1 lukem fi
350 1.1 lukem
351 1.1.1.2 lukem echo "Waiting $SLEEP1 seconds for syncrepl to receive changes..."
352 1.1.1.2 lukem sleep $SLEEP1
353 1.1 lukem fi
354 1.1 lukem
355 1.1.1.4 tron echo "Using ldapsearch to read all the entries from the provider..."
356 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT1 \
357 1.1 lukem 'objectclass=*' \* + > $MASTEROUT 2>&1
358 1.1 lukem RC=$?
359 1.1 lukem
360 1.1 lukem if test $RC != 0 ; then
361 1.1.1.4 tron echo "ldapsearch failed at provider ($RC)!"
362 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
363 1.1 lukem exit $RC
364 1.1 lukem fi
365 1.1 lukem
366 1.1 lukem echo "Using ldapsearch to read all the entries from the consumer..."
367 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT2 \
368 1.1 lukem 'objectclass=*' \* + > $SLAVEOUT 2>&1
369 1.1 lukem RC=$?
370 1.1 lukem
371 1.1 lukem if test $RC != 0 ; then
372 1.1 lukem echo "ldapsearch failed at consumer ($RC)!"
373 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
374 1.1 lukem exit $RC
375 1.1 lukem fi
376 1.1 lukem
377 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
378 1.1 lukem
379 1.1.1.4 tron echo "Filtering provider results..."
380 1.1.1.4.10.1 bouyer $LDIFFILTER -b $BACKEND -s $SPEC < $MASTEROUT | grep -iv "^auditcontext:" > $MASTERFLT
381 1.1 lukem echo "Filtering consumer results..."
382 1.1.1.4.10.1 bouyer $LDIFFILTER -b $BACKEND -s $SPEC < $SLAVEOUT | grep -iv "^auditcontext:" > $SLAVEFLT
383 1.1 lukem
384 1.1.1.4 tron echo "Comparing retrieved entries from provider and consumer..."
385 1.1 lukem $CMP $MASTERFLT $SLAVEFLT > $CMPOUT
386 1.1 lukem
387 1.1 lukem if test $? != 0 ; then
388 1.1.1.4 tron echo "test failed - provider and consumer databases differ"
389 1.1 lukem exit 1
390 1.1 lukem fi
391 1.1 lukem
392 1.1 lukem echo ">>>>> Test succeeded"
393 1.1 lukem
394 1.1 lukem test $KILLSERVERS != no && wait
395 1.1 lukem
396 1.1 lukem exit 0
397