Skip to content
GitLab
Explore
Sign in
Register
Primary navigation
Search or go to…
Project
O
OpenLDAP
Manage
Activity
Members
Labels
Plan
Wiki
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Locked files
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Package registry
Container Registry
Model registry
Operate
Environments
Terraform modules
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Code review analytics
Insights
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Christopher Ng
OpenLDAP
Commits
910f8ba2
Commit
910f8ba2
authored
18 years ago
by
Howard Chu
Browse files
Options
Downloads
Patches
Plain Diff
Preliminary multimaster replication test
parent
b5d83415
No related branches found
Branches containing commit
No related tags found
Tags containing commit
No related merge requests found
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
tests/scripts/test050-syncrepl-multimaster
+435
-0
435 additions, 0 deletions
tests/scripts/test050-syncrepl-multimaster
with
435 additions
and
0 deletions
tests/scripts/test050-syncrepl-multimaster
0 → 100755
+
435
−
0
View file @
910f8ba2
#! /bin/sh
# $OpenLDAP$
## This work is part of OpenLDAP Software <http://www.openldap.org/>.
##
## Copyright 1998-2007 The OpenLDAP Foundation.
## All rights reserved.
##
## Redistribution and use in source and binary forms, with or without
## modification, are permitted only as authorized by the OpenLDAP
## Public License.
##
## A copy of this license is available in the file LICENSE in the
## top-level directory of the distribution or, alternatively, at
## <http://www.OpenLDAP.org/license.html>.
echo
"running defines.sh"
.
$SRCDIR
/scripts/defines.sh
if
test
$SYNCPROV
=
syncprovno
;
then
echo
"Syncrepl provider overlay not available, test skipped"
exit
0
fi
PRODIR
=
$TESTDIR
/pro
CONDIR
=
$TESTDIR
/con
DBPRO
=
$PRODIR
/db
DBCON
=
$CONDIR
/db
CFPRO
=
$PRODIR
/slapd.d
CFCON
=
$CONDIR
/slapd.d
LOG1
=
slapd.1.log
LOG2
=
slapd.2.log
mkdir
-p
$TESTDIR
$PRODIR
$CONDIR
$DBPRO
$DBCON
$CFPRO
$CFCON
#
# Test replication of dynamic config:
# - start producer
# - start consumer
# - configure over ldap
# - populate over ldap
# - configure syncrepl over ldap
# - retrieve database over ldap and compare against expected results
#
echo
"Initializing server configurations..."
$SLAPADD
-F
$CFPRO
-n
0
-l
$DYNAMICCONF
$SLAPADD
-F
$CFCON
-n
0
-l
$DYNAMICCONF
echo
"Starting producer slapd on TCP/IP port
$PORT1
..."
cd
$PRODIR
$SLAPD
-F
./slapd.d
-h
$URI1
-d
$LVL
$TIMING
>
../
$LOG1
2>&1 &
PID
=
$!
if
test
$WAIT
!=
0
;
then
echo
PID
$PID
read
foo
fi
KILLPIDS
=
"
$PID
"
cd
../..
sleep
1
echo
"Using ldapsearch to check that producer slapd is running..."
for
i
in
0 1 2 3 4 5
;
do
$LDAPSEARCH
-s
base
-b
""
-H
$URI1
\
'objectclass=*'
>
/dev/null 2>&1
RC
=
$?
if
test
$RC
=
0
;
then
break
fi
echo
"Waiting 5 seconds for slapd to start..."
sleep
5
done
if
test
$RC
!=
0
;
then
echo
"ldapsearch failed (
$RC
)!"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
$RC
fi
echo
"Inserting syncprov overlay on producer..."
if
[
"
$SYNCPROV
"
=
syncprovmod
]
;
then
$LDAPADD
-D
cn
=
config
-H
$URI1
-y
$CONFIGPWF
<<
EOF
>
$TESTOUT
2>&1
dn: cn=module,cn=config
objectClass: olcModuleList
cn: module
olcModulePath: ../../../servers/slapd/overlays
olcModuleLoad: syncprov.la
EOF
RC
=
$?
if
test
$RC
!=
0
;
then
echo
"ldapadd failed for moduleLoad (
$RC
)!"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
$RC
fi
fi
#
# Note that we configure a timeout here; it's possible for both
# servers to attempt to bind to each other while a modify to
# cn=config is in progress. When the modify pauses the thread pool
# neither server will progress. The timeout will drop the syncrepl
# attempt and allow the modifies to complete.
#
# Setting the ServerIDs after the fact is bogus; the entries that
# were created before this point all have SID 0 in their CSNs. Still
# that should be harmless.
#
CONFIGPW
=
`
cat
$CONFIGPWF
`
$LDAPMODIFY
-D
cn
=
config
-H
$URI1
-y
$CONFIGPWF
<<
EOF
>>
$TESTOUT
2>&1
dn: cn=config
changetype: modify
add: olcServerID
olcServerID: 1
$URI1
olcServerID: 2
$URI2
dn: olcOverlay=syncprov,olcDatabase={0}config,cn=config
changetype: add
objectClass: olcOverlayConfig
objectClass: olcSyncProvConfig
olcOverlay: syncprov
dn: olcDatabase={0}config,cn=config
changetype: modify
add: olcSyncRepl
olcSyncRepl: rid=001 provider=
$URI1
binddn="cn=config" bindmethod=simple
credentials=
$CONFIGPW
searchbase="cn=config" type=refreshAndPersist
retry="5 5 300 5" timeout=1
olcSyncRepl: rid=002 provider=
$URI2
binddn="cn=config" bindmethod=simple
credentials=
$CONFIGPW
searchbase="cn=config" type=refreshAndPersist
retry="5 5 300 5" timeout=1
-
add: olcMirrorMode
olcMirrorMode: TRUE
EOF
RC
=
$?
if
test
$RC
!=
0
;
then
echo
"ldapmodify failed for syncrepl config (
$RC
)!"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
$RC
fi
echo
"Starting consumer slapd on TCP/IP port
$PORT2
..."
cd
$CONDIR
$SLAPD
-F
./slapd.d
-h
$URI2
-d
$LVL
$TIMING
>
../
$LOG2
2>&1 &
SLAVEPID
=
$!
if
test
$WAIT
!=
0
;
then
echo
SLAVEPID
$SLAVEPID
read
foo
fi
KILLPIDS
=
"
$KILLPIDS
$SLAVEPID
"
cd
../..
sleep
1
echo
"Using ldapsearch to check that consumer slapd is running..."
for
i
in
0 1 2 3 4 5
;
do
$LDAPSEARCH
-s
base
-b
""
-H
$URI2
\
'objectclass=*'
>
/dev/null 2>&1
RC
=
$?
if
test
$RC
=
0
;
then
break
fi
echo
"Waiting 5 seconds for slapd to start..."
sleep
5
done
if
test
$RC
!=
0
;
then
echo
"ldapsearch failed (
$RC
)!"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
$RC
fi
echo
"Configuring syncrepl on consumer..."
$LDAPMODIFY
-D
cn
=
config
-H
$URI2
-y
$CONFIGPWF
<<
EOF
>>
$TESTOUT
2>&1
dn: olcDatabase={0}config,cn=config
changetype: modify
add: olcSyncRepl
olcSyncRepl: rid=001 provider=
$URI1
binddn="cn=config" bindmethod=simple
credentials=
$CONFIGPW
searchbase="cn=config" type=refreshAndPersist
retry="5 5 300 5" timeout=1
olcSyncRepl: rid=002 provider=
$URI2
binddn="cn=config" bindmethod=simple
credentials=
$CONFIGPW
searchbase="cn=config" type=refreshAndPersist
retry="5 5 300 5" timeout=1
-
add: olcMirrorMode
olcMirrorMode: TRUE
EOF
echo
"Adding schema and databases on producer..."
$LDAPADD
-D
cn
=
config
-H
$URI1
-y
$CONFIGPWF
<<
EOF
>>
$TESTOUT
2>&1
include: file:
$SCHEMADIR
/core.ldif
include: file:
$SCHEMADIR
/cosine.ldif
include: file:
$SCHEMADIR
/inetorgperson.ldif
include: file:
$SCHEMADIR
/openldap.ldif
include: file:
$SCHEMADIR
/nis.ldif
EOF
RC
=
$?
if
test
$RC
!=
0
;
then
echo
"ldapadd failed for schema config (
$RC
)!"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
$RC
fi
if
[
"
$BACKENDTYPE
"
=
mod
]
;
then
$LDAPADD
-D
cn
=
config
-H
$URI1
-y
$CONFIGPWF
<<
EOF
>>
$TESTOUT
2>&1
dn: cn=module,cn=config
objectClass: olcModuleList
cn: module
olcModulePath: ../../../servers/slapd/back-
$BACKEND
olcModuleLoad: back_
$BACKEND
.la
EOF
RC
=
$?
if
test
$RC
!=
0
;
then
echo
"ldapadd failed for backend config (
$RC
)!"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
$RC
fi
fi
$LDAPADD
-D
cn
=
config
-H
$URI1
-y
$CONFIGPWF
<<
EOF
>>
$TESTOUT
2>&1
dn: olcDatabase={1}
$BACKEND
,cn=config
objectClass: olcDatabaseConfig
objectClass: olc
${
BACKEND
}
Config
olcDatabase: {1}
$BACKEND
olcSuffix:
$BASEDN
olcDbDirectory: ./db
olcRootDN:
$MANAGERDN
olcRootPW:
$PASSWD
olcSyncRepl: rid=003 provider=
$URI1
binddn="
$MANAGERDN
" bindmethod=simple
credentials=
$PASSWD
searchbase="
$BASEDN
" type=refreshOnly
interval=00:00:00:10 retry="5 5 300 5"
olcSyncRepl: rid=004 provider=
$URI2
binddn="
$MANAGERDN
" bindmethod=simple
credentials=
$PASSWD
searchbase="
$BASEDN
" type=refreshOnly
interval=00:00:00:10 retry="5 5 300 5"
olcMirrorMode: TRUE
dn: olcOverlay=syncprov,olcDatabase={1}
${
BACKEND
}
,cn=config
changetype: add
objectClass: olcOverlayConfig
objectClass: olcSyncProvConfig
olcOverlay: syncprov
EOF
RC
=
$?
if
test
$RC
!=
0
;
then
echo
"ldapadd failed for database config (
$RC
)!"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
$RC
fi
echo
"Using ldapadd to populate producer..."
$LDAPADD
-D
"
$MANAGERDN
"
-H
$URI1
-w
$PASSWD
-f
$LDIFORDERED
\
>>
$TESTOUT
2>&1
RC
=
$?
if
test
$RC
!=
0
;
then
echo
"ldapadd failed for database config (
$RC
)!"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
$RC
fi
SLEEP
=
20
echo
"Waiting
$SLEEP
seconds for syncrepl to receive changes..."
sleep
$SLEEP
echo
"Using ldapsearch to check that syncrepl received database changes..."
RC
=
32
for
i
in
0 1 2 3 4 5
;
do
RESULT
=
`
$LDAPSEARCH
-H
$URI2
\
-s
base
-b
"cn=Ursula Hampster,ou=Alumni Association,ou=People,dc=example,dc=com"
\
'(objectClass=*)'
2>&1 |
awk
'/^dn:/ {print "OK"}'
`
if
test
"x
$RESULT
"
=
"xOK"
;
then
RC
=
0
break
fi
echo
"Waiting 5 seconds for syncrepl to receive changes..."
sleep
5
done
if
test
$RC
!=
0
;
then
echo
"ldapsearch failed (
$RC
)!"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
$RC
fi
echo
"Using ldapsearch to read config from the producer..."
$LDAPSEARCH
-b
cn
=
config
-D
cn
=
config
-H
$URI1
-y
$CONFIGPWF
\
'objectclass=*'
>
$MASTEROUT
2>&1
RC
=
$?
if
test
$RC
!=
0
;
then
echo
"ldapsearch failed at producer (
$RC
)!"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
$RC
fi
echo
"Using ldapsearch to read config from the consumer..."
$LDAPSEARCH
-b
cn
=
config
-D
cn
=
config
-H
$URI2
-y
$CONFIGPWF
\
'objectclass=*'
>
$SLAVEOUT
2>&1
RC
=
$?
if
test
$RC
!=
0
;
then
echo
"ldapsearch failed at consumer (
$RC
)!"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
$RC
fi
echo
"Filtering producer results..."
.
$LDIFFILTER
<
$MASTEROUT
>
$MASTERFLT
echo
"Filtering consumer results..."
.
$LDIFFILTER
<
$SLAVEOUT
>
$SLAVEFLT
echo
"Comparing retrieved configs from producer and consumer..."
$CMP
$MASTERFLT
$SLAVEFLT
>
$CMPOUT
if
test
$?
!=
0
;
then
echo
"test failed - producer and consumer configs differ"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
1
fi
echo
"Using ldapsearch to read all the entries from the producer..."
$LDAPSEARCH
-S
""
-b
"
$BASEDN
"
-D
"
$MANAGERDN
"
-H
$URI1
-w
$PASSWD
\
'objectclass=*'
>
$MASTEROUT
2>&1
RC
=
$?
if
test
$RC
!=
0
;
then
echo
"ldapsearch failed at producer (
$RC
)!"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
$RC
fi
echo
"Using ldapsearch to read all the entries from the consumer..."
$LDAPSEARCH
-S
""
-b
"
$BASEDN
"
-D
"
$MANAGERDN
"
-H
$URI2
-w
$PASSWD
\
'objectclass=*'
>
$SLAVEOUT
2>&1
RC
=
$?
if
test
$RC
!=
0
;
then
echo
"ldapsearch failed at consumer (
$RC
)!"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
$RC
fi
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
echo
"Filtering producer results..."
.
$LDIFFILTER
<
$MASTEROUT
>
$MASTERFLT
echo
"Filtering consumer results..."
.
$LDIFFILTER
<
$SLAVEOUT
>
$SLAVEFLT
echo
"Comparing retrieved entries from producer and consumer..."
$CMP
$MASTERFLT
$SLAVEFLT
>
$CMPOUT
if
test
$?
!=
0
;
then
echo
"test failed - producer and consumer databases differ"
exit
1
fi
test
$KILLSERVERS
!=
no
&&
wait
echo
"Restarting servers..."
echo
"Starting producer slapd on TCP/IP port
$PORT1
..."
cd
$PRODIR
echo
"======================= RESTART ======================="
>>
../
$LOG1
$SLAPD
-F
./slapd.d
-h
$URI1
-d
$LVL
$TIMING
>>
../
$LOG1
2>&1 &
PID
=
$!
if
test
$WAIT
!=
0
;
then
echo
PID
$PID
read
foo
fi
KILLPIDS
=
"
$PID
"
cd
../..
echo
"Using ldapsearch to check that producer slapd is running..."
for
i
in
0 1 2 3 4 5
;
do
$LDAPSEARCH
-s
base
-b
""
-H
$URI1
\
'objectclass=*'
>
/dev/null 2>&1
RC
=
$?
if
test
$RC
=
0
;
then
break
fi
echo
"Waiting 5 seconds for slapd to start..."
sleep
5
done
if
test
$RC
!=
0
;
then
echo
"ldapsearch failed (
$RC
)!"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
$RC
fi
#exit 0
echo
"Starting consumer slapd on TCP/IP port
$PORT2
..."
cd
$CONDIR
echo
"======================= RESTART ======================="
>>
../
$LOG2
$SLAPD
-F
./slapd.d
-h
$URI2
-d
$LVL
$TIMING
>>
../
$LOG2
2>&1 &
SLAVEPID
=
$!
if
test
$WAIT
!=
0
;
then
echo
SLAVEPID
$SLAVEPID
read
foo
fi
KILLPIDS
=
"
$KILLPIDS
$SLAVEPID
"
cd
../..
sleep
1
echo
"Using ldapsearch to check that consumer slapd is running..."
for
i
in
0 1 2 3 4 5
;
do
$LDAPSEARCH
-s
base
-b
""
-H
$URI2
\
'objectclass=*'
>
/dev/null 2>&1
RC
=
$?
if
test
$RC
=
0
;
then
break
fi
echo
"Waiting 5 seconds for slapd to start..."
sleep
5
done
if
test
$RC
!=
0
;
then
echo
"ldapsearch failed (
$RC
)!"
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
exit
$RC
fi
# Insert modifications and more tests here.
SLEEP
=
10
echo
"Waiting
$SLEEP
seconds for servers to resync..."
sleep
$SLEEP
test
$KILLSERVERS
!=
no
&&
kill
-HUP
$KILLPIDS
echo
">>>>> Test succeeded"
test
$KILLSERVERS
!=
no
&&
wait
exit
0
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment