]> git.sur5r.net Git - openldap/blob - tests/scripts/test012-glue
Fix return code tests.
[openldap] / tests / scripts / test012-glue
1 #! /bin/sh
2 # $OpenLDAP$
3
4 SRCDIR="."
5 if test $# -ge 1 ; then
6         SRCDIR=$1; shift
7 fi
8 BACKEND=bdb
9 if test $# -ge 1 ; then
10         BACKEND=$1; shift
11 fi
12 WAIT=0
13 if test $# -ge 1 ; then
14         WAIT=1; shift
15 fi
16
17 echo "running defines.sh"
18 . $SRCDIR/scripts/defines.sh
19
20 echo "Cleaning up in $DBDIR..."
21
22 mkdir $DBDIR/C_db1 $DBDIR/C_db2 $DBDIR/C_db3
23
24 rm -f $DBDIR/[!C]* $DBDIR/C_db?/*
25
26 echo "Running slapadd to build glued slapd databases..."
27 . $CONFFILTER $BACKEND < $GLUECONF > $DBCONF
28 $SLAPADD -d $LVL -f $DBCONF -l $LDIFORDERED > $DBDIR/slapadd.log 2>&1
29 RC=$?
30 if test $RC != 0 ; then
31         echo "slapadd failed ($RC)!"
32         exit $RC
33 fi
34
35 echo "Starting slapd on TCP/IP port $PORT..."
36 $SLAPD -f $DBCONF -h $MASTERURI -d $LVL $TIMING > $MASTERLOG 2>&1 &
37 PID=$!
38 if test $WAIT != 0 ; then
39     echo PID $PID
40     read foo
41 fi
42
43 echo "Using ldapsearch to retrieve all the entries..."
44 cd test-db
45 for i in 0 1 2 3 4 5; do
46         ../$LDAPSEARCH -b "$BASEDN" -h $LOCALHOST -p $PORT > ../$SEARCHOUT 2>&1
47         RC=$?
48         if test $RC = 1 ; then
49                 echo "Waiting 5 seconds for slapd to start..."
50                 sleep 5
51         fi
52 done
53 cd ..
54
55 kill -HUP $PID
56 echo "Sleeping for 5 seconds to let slapd exit..."
57 sleep 5
58
59 if test $RC != 0 ; then
60         echo "ldapsearch failed ($RC)!"
61         exit $RC
62 fi
63
64 echo "Filtering ldapsearch results..."
65 . $LDIFFILTER < $SEARCHOUT > $SEARCHFLT
66 echo "Filtering original ldif used to create database..."
67 . $LDIFFILTER < $LDIFGLUED > $LDIFFLT
68 echo "Comparing filter output..."
69 $CMP $SEARCHFLT $LDIFFLT > $CMPOUT
70
71 if test $? != 0 ; then
72         echo "comparison failed - database was not created correctly"
73         echo $SEARCHFLT $LDIFFLT
74         $DIFF $SEARCHFLT $LDIFFLT
75         exit 1
76 fi
77
78 echo "OK...  Cleaning up in $DBDIR..."
79
80 rm -f $DBDIR/C_db?/*
81
82 echo "Starting slapd on TCP/IP port $PORT..."
83 $SLAPD -f $DBCONF -h $MASTERURI -d $LVL $TIMING > $MASTERLOG 2>&1 &
84 PID=$!
85 if test $WAIT != 0 ; then
86     echo PID $PID
87     read foo
88 fi
89
90 echo "Using ldapsearch to check that slapd is running..."
91 for i in 0 1 2 3 4 5; do
92         $LDAPSEARCH -s base -b "$MONITOR" -h $LOCALHOST -p $PORT \
93                 'objectclass=*' > /dev/null 2>&1
94         RC=$?
95         if test $RC = 1 ; then
96                 echo "Waiting 5 seconds for slapd to start..."
97                 sleep 5
98         fi
99 done
100
101 echo "Using ldapadd to populate the glued database..."
102 $LDAPADD -D "$MANAGERDN" -h $LOCALHOST -p $PORT -w $PASSWD < \
103         $LDIFORDERED > $TESTOUT 2>&1
104 RC=$?
105 if test $RC != 0 ; then
106         echo "ldapadd failed ($RC)!"
107         kill -HUP $PID
108         exit $RC
109 fi
110
111 echo "Using ldapsearch to read all the entries..."
112 $LDAPSEARCH -b "$BASEDN" -h $LOCALHOST -p $PORT \
113         'objectclass=*' > $SEARCHOUT 2>&1
114 RC=$?
115
116 kill -HUP $PID
117
118 if test $RC != 0 ; then
119         echo "ldapsearch failed ($RC)!"
120         exit $RC
121 fi
122
123 echo "Filtering ldapsearch results..."
124 . $LDIFFILTER < $SEARCHOUT > $SEARCHFLT
125 echo "Filtering original ldif used to create database..."
126 . $LDIFFILTER < $LDIFGLUED > $LDIFFLT
127 echo "Comparing filter output..."
128 $CMP $SEARCHFLT $LDIFFLT > $CMPOUT
129
130 if test $? != 0 ; then
131         echo "comparison failed - database was not created correctly"
132         exit 1
133 fi
134
135 echo ">>>>> Test succeeded"
136
137
138 exit 0