test057-memberof-refint revision 1.1.1.3 1 1.1 lukem #! /bin/sh
2 1.1.1.3 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.3 tron ## Copyright 1998-2014 The OpenLDAP Foundation.
6 1.1 lukem ## Portions Copyright 2008 Red Hat, Inc.
7 1.1 lukem ## All rights reserved.
8 1.1 lukem ##
9 1.1 lukem ## Redistribution and use in source and binary forms, with or without
10 1.1 lukem ## modification, are permitted only as authorized by the OpenLDAP
11 1.1 lukem ## Public License.
12 1.1 lukem ##
13 1.1 lukem ## A copy of this license is available in the file LICENSE in the
14 1.1 lukem ## top-level directory of the distribution or, alternatively, at
15 1.1 lukem ## <http://www.OpenLDAP.org/license.html>.
16 1.1 lukem
17 1.1 lukem echo "running defines.sh"
18 1.1 lukem . $SRCDIR/scripts/defines.sh
19 1.1 lukem
20 1.1 lukem if test $MEMBEROF = memberofno; then
21 1.1 lukem echo "Memberof overlay not available, test skipped"
22 1.1 lukem exit 0
23 1.1 lukem fi
24 1.1 lukem
25 1.1 lukem if test $REFINT = refintno; then
26 1.1 lukem echo "Referential Integrity overlay not available, test skipped"
27 1.1 lukem exit 0
28 1.1 lukem fi
29 1.1 lukem
30 1.1.1.2 adam if test $BACKEND = bdb; then
31 1.1.1.2 adam echo "$BACKEND backend does not support subtree rename, test skipped"
32 1.1 lukem exit 0
33 1.1 lukem fi
34 1.1 lukem
35 1.1 lukem mkdir -p $TESTDIR $DBDIR1 $TESTDIR/confdir
36 1.1 lukem
37 1.1 lukem $SLAPPASSWD -g -n >$CONFIGPWF
38 1.1 lukem echo "rootpw `$SLAPPASSWD -T $CONFIGPWF`" >$TESTDIR/configpw.conf
39 1.1 lukem
40 1.1 lukem echo "Starting slapd on TCP/IP port $PORT1..."
41 1.1 lukem . $CONFFILTER $BACKEND $MONITORDB < $NAKEDCONF > $CONF1
42 1.1 lukem $SLAPD -f $CONF1 -F $TESTDIR/confdir -h $URI1 -d $LVL $TIMING > $LOG1 2>&1 &
43 1.1 lukem PID=$!
44 1.1 lukem if test $WAIT != 0 ; then
45 1.1 lukem echo PID $PID
46 1.1 lukem read foo
47 1.1 lukem fi
48 1.1 lukem KILLPIDS="$PID"
49 1.1 lukem
50 1.1 lukem sleep 1
51 1.1 lukem for i in 0 1 2 3 4 5; do
52 1.1 lukem $LDAPSEARCH -s base -b "$MONITOR" -h $LOCALHOST -p $PORT1 \
53 1.1 lukem 'objectclass=*' > /dev/null 2>&1
54 1.1 lukem RC=$?
55 1.1 lukem if test $RC = 0 ; then
56 1.1 lukem break
57 1.1 lukem fi
58 1.1 lukem echo "Waiting 5 seconds for slapd to start..."
59 1.1 lukem sleep 5
60 1.1 lukem done
61 1.1 lukem if test $RC != 0 ; then
62 1.1 lukem echo "ldapsearch failed ($RC)!"
63 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
64 1.1 lukem exit $RC
65 1.1 lukem fi
66 1.1 lukem
67 1.1 lukem cat /dev/null > $TESTOUT
68 1.1 lukem
69 1.1.1.3 tron indexInclude="" mainInclude="" bdbInclude="# " nullExclude=""
70 1.1.1.3 tron test $INDEXDB = indexdb || indexInclude="# "
71 1.1.1.3 tron test $MAINDB = maindb || mainInclude="# "
72 1.1.1.2 adam case $BACKEND in
73 1.1.1.2 adam bdb | hdb) bdbInclude="" ;;
74 1.1.1.2 adam null) nullExclude="# " ;;
75 1.1.1.2 adam esac
76 1.1.1.2 adam
77 1.1 lukem if [ "$MEMBEROF" = memberofmod ]; then
78 1.1.1.3 tron echo "Inserting memberof overlay on provider..."
79 1.1 lukem $LDAPADD -D cn=config -H $URI1 -y $CONFIGPWF <<EOF > $TESTOUT 2>&1
80 1.1 lukem dn: cn=module,cn=config
81 1.1 lukem objectClass: olcModuleList
82 1.1 lukem cn: module
83 1.1 lukem olcModulePath: ../servers/slapd/overlays
84 1.1 lukem olcModuleLoad: memberof.la
85 1.1 lukem olcModuleLoad: refint.la
86 1.1 lukem EOF
87 1.1 lukem RC=$?
88 1.1 lukem if test $RC != 0 ; then
89 1.1 lukem echo "ldapadd failed for moduleLoad ($RC)!"
90 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
91 1.1 lukem exit $RC
92 1.1 lukem fi
93 1.1 lukem fi
94 1.1 lukem
95 1.1 lukem echo "Running ldapadd to build slapd config database..."
96 1.1 lukem $LDAPADD -h $LOCALHOST -p $PORT1 -D 'cn=config' -w `cat $CONFIGPWF` \
97 1.1 lukem >> $TESTOUT 2>&1 <<EOF
98 1.1 lukem dn: olcDatabase={1}$BACKEND,cn=config
99 1.1 lukem objectClass: olcDatabaseConfig
100 1.1.1.2 adam ${nullExclude}objectClass: olc${BACKEND}Config
101 1.1 lukem olcDatabase: {1}$BACKEND
102 1.1 lukem olcSuffix: $BASEDN
103 1.1 lukem olcRootDN: cn=Manager,$BASEDN
104 1.1 lukem olcRootPW:: c2VjcmV0
105 1.1 lukem olcMonitoring: TRUE
106 1.1.1.2 adam ${nullExclude}olcDbDirectory: $TESTDIR/db.1.a/
107 1.1.1.2 adam ${bdbInclude}olcDbCacheSize: 1000
108 1.1.1.3 tron ${indexInclude}olcDbIndex: objectClass eq
109 1.1.1.3 tron ${indexInclude}olcDbIndex: cn pres,eq,sub
110 1.1.1.3 tron ${indexInclude}olcDbIndex: uid pres,eq,sub
111 1.1.1.3 tron ${indexInclude}olcDbIndex: sn pres,eq,sub
112 1.1.1.3 tron ${mainInclude}olcDbMode: 384
113 1.1 lukem
114 1.1 lukem # {0}memberof, {1}$BACKEND, config
115 1.1 lukem dn: olcOverlay={0}memberof,olcDatabase={1}$BACKEND,cn=config
116 1.1 lukem objectClass: olcOverlayConfig
117 1.1 lukem objectClass: olcMemberOf
118 1.1 lukem olcOverlay: {0}memberof
119 1.1 lukem olcMemberOfRefInt: TRUE
120 1.1 lukem olcMemberOfGroupOC: groupOfNames
121 1.1 lukem olcMemberOfMemberAD: member
122 1.1 lukem olcMemberOfMemberOfAD: memberOf
123 1.1 lukem
124 1.1 lukem # {1}refint, {1}$BACKEND, config
125 1.1 lukem dn: olcOverlay={1}refint,olcDatabase={1}$BACKEND,cn=config
126 1.1 lukem objectClass: olcOverlayConfig
127 1.1 lukem objectClass: olcRefintConfig
128 1.1 lukem olcOverlay: {1}refint
129 1.1 lukem olcRefintAttribute: member
130 1.1 lukem olcRefintAttribute: memberOf
131 1.1 lukem EOF
132 1.1 lukem RC=$?
133 1.1 lukem if test $RC != 0 ; then
134 1.1 lukem echo "ldapadd failed ($RC)!"
135 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
136 1.1 lukem exit $RC
137 1.1 lukem fi
138 1.1 lukem
139 1.1 lukem echo "Running ldapadd to build slapd database..."
140 1.1 lukem $LDAPADD -h $LOCALHOST -p $PORT1 \
141 1.1 lukem -D "cn=Manager,$BASEDN" -w secret \
142 1.1 lukem >> $TESTOUT 2>&1 << EOF
143 1.1 lukem dn: $BASEDN
144 1.1 lukem objectClass: organization
145 1.1 lukem objectClass: dcObject
146 1.1 lukem o: Example, Inc.
147 1.1 lukem dc: example
148 1.1 lukem
149 1.1 lukem dn: ou=People,$BASEDN
150 1.1 lukem objectClass: organizationalUnit
151 1.1 lukem ou: People
152 1.1 lukem
153 1.1 lukem dn: ou=Groups,$BASEDN
154 1.1 lukem objectClass: organizationalUnit
155 1.1 lukem ou: Groups
156 1.1 lukem
157 1.1 lukem dn: cn=Roger Rabbit,ou=People,$BASEDN
158 1.1 lukem objectClass: inetOrgPerson
159 1.1 lukem cn: Roger Rabbit
160 1.1 lukem sn: Rabbit
161 1.1 lukem
162 1.1 lukem dn: cn=Baby Herman,ou=People,$BASEDN
163 1.1 lukem objectClass: inetOrgPerson
164 1.1 lukem cn: Baby Herman
165 1.1 lukem sn: Herman
166 1.1 lukem
167 1.1 lukem dn: cn=Cartoonia,ou=Groups,$BASEDN
168 1.1 lukem objectClass: groupOfNames
169 1.1 lukem cn: Cartoonia
170 1.1 lukem member: cn=Roger Rabbit,ou=People,$BASEDN
171 1.1 lukem member: cn=Baby Herman,ou=People,$BASEDN
172 1.1 lukem EOF
173 1.1 lukem RC=$?
174 1.1 lukem if test $RC != 0 ; then
175 1.1 lukem echo "ldapadd failed ($RC)!"
176 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
177 1.1 lukem exit $RC
178 1.1 lukem fi
179 1.1 lukem
180 1.1 lukem echo "Search the entire database..."
181 1.1 lukem echo "# Search the entire database..." >> $SEARCHOUT
182 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT1 \
183 1.1 lukem '(objectClass=*)' '*' memberOf >> $SEARCHOUT 2>&1
184 1.1 lukem RC=$?
185 1.1 lukem if test $RC != 0 ; then
186 1.1 lukem echo "ldapsearch failed ($RC)!"
187 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
188 1.1 lukem exit $RC
189 1.1 lukem fi
190 1.1 lukem
191 1.1 lukem echo "Running ldapmodify to rename subtree..."
192 1.1 lukem $LDAPMODIFY -h $LOCALHOST -p $PORT1 \
193 1.1 lukem -D "cn=Manager,$BASEDN" -w secret \
194 1.1 lukem >> $TESTOUT 2>&1 << EOF
195 1.1 lukem dn: ou=People,$BASEDN
196 1.1 lukem changetype: modrdn
197 1.1 lukem newrdn: ou=Toons
198 1.1 lukem deleteoldrdn:1
199 1.1 lukem newsuperior: $BASEDN
200 1.1 lukem EOF
201 1.1 lukem
202 1.1 lukem # refint runs in a background thread, so it most likely won't complete
203 1.1 lukem # before the modify returns. Give it some time to execute.
204 1.1.1.3 tron sleep $SLEEP0
205 1.1 lukem
206 1.1 lukem echo "Re-search the entire database..."
207 1.1 lukem echo "# Re-search the entire database..." >> $SEARCHOUT
208 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT1 \
209 1.1 lukem '(objectClass=*)' '*' memberOf >> $SEARCHOUT 2>&1
210 1.1 lukem RC=$?
211 1.1 lukem if test $RC != 0 ; then
212 1.1 lukem echo "ldapsearch failed ($RC)!"
213 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
214 1.1 lukem exit $RC
215 1.1 lukem fi
216 1.1 lukem
217 1.1 lukem echo "Running ldapmodify to rename subtree..."
218 1.1 lukem $LDAPMODIFY -h $LOCALHOST -p $PORT1 \
219 1.1 lukem -D "cn=Manager,$BASEDN" -w secret \
220 1.1 lukem >> $TESTOUT 2>&1 << EOF
221 1.1 lukem dn: ou=Groups,$BASEDN
222 1.1 lukem changetype: modrdn
223 1.1 lukem newrdn: ou=Studios
224 1.1 lukem deleteoldrdn:1
225 1.1 lukem newsuperior: $BASEDN
226 1.1 lukem EOF
227 1.1 lukem
228 1.1.1.3 tron sleep $SLEEP0
229 1.1 lukem
230 1.1 lukem echo "Re-search the entire database..."
231 1.1 lukem echo "# Re-search the entire database..." >> $SEARCHOUT
232 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT1 \
233 1.1 lukem '(objectClass=*)' '*' memberOf >> $SEARCHOUT 2>&1
234 1.1 lukem RC=$?
235 1.1 lukem if test $RC != 0 ; then
236 1.1 lukem echo "ldapsearch failed ($RC)!"
237 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
238 1.1 lukem exit $RC
239 1.1 lukem fi
240 1.1 lukem
241 1.1 lukem echo "Running ldapdelete to remove a member..."
242 1.1 lukem $LDAPMODIFY -h $LOCALHOST -p $PORT1 \
243 1.1 lukem -D "cn=Manager,$BASEDN" -w secret \
244 1.1 lukem >> $TESTOUT 2>&1 << EOF
245 1.1 lukem dn: cn=Baby Herman,ou=Toons,$BASEDN
246 1.1 lukem changetype: delete
247 1.1 lukem EOF
248 1.1 lukem
249 1.1.1.3 tron sleep $SLEEP0
250 1.1 lukem
251 1.1 lukem echo "Re-search the entire database..."
252 1.1 lukem echo "# Re-search the entire database..." >> $SEARCHOUT
253 1.1 lukem $LDAPSEARCH -S "" -b "$BASEDN" -h $LOCALHOST -p $PORT1 \
254 1.1 lukem '(objectClass=*)' '*' memberOf >> $SEARCHOUT 2>&1
255 1.1 lukem RC=$?
256 1.1 lukem if test $RC != 0 ; then
257 1.1 lukem echo "ldapsearch failed ($RC)!"
258 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
259 1.1 lukem exit $RC
260 1.1 lukem fi
261 1.1 lukem
262 1.1 lukem test $KILLSERVERS != no && kill -HUP $KILLPIDS
263 1.1 lukem
264 1.1 lukem LDIF=$MEMBEROFREFINTOUT
265 1.1 lukem
266 1.1 lukem echo "Filtering ldapsearch results..."
267 1.1.1.2 adam $LDIFFILTER < $SEARCHOUT > $SEARCHFLT
268 1.1 lukem echo "Filtering original ldif used to create database..."
269 1.1.1.2 adam $LDIFFILTER < $LDIF > $LDIFFLT
270 1.1 lukem echo "Comparing filter output..."
271 1.1 lukem $CMP $SEARCHFLT $LDIFFLT > $CMPOUT
272 1.1 lukem
273 1.1 lukem if test $? != 0 ; then
274 1.1 lukem echo "Comparison failed"
275 1.1 lukem exit 1
276 1.1 lukem fi
277 1.1 lukem
278 1.1 lukem echo ">>>>> Test succeeded"
279 1.1 lukem
280 1.1 lukem test $KILLSERVERS != no && wait
281 1.1 lukem
282 1.1 lukem exit 0
283