X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=tests%2Fscripts%2Ftest036-meta-concurrency;h=958f7842e36ec71384d6a8a0c0e2441d51aca604;hb=3cb9d64de3d2fe9d0e80a9a631335b909f7b64b4;hp=d430732638be13369703645656feee7a1d04e546;hpb=637df0ba906dccf26a3eaf02fa559fabb2bd1e19;p=openldap diff --git a/tests/scripts/test036-meta-concurrency b/tests/scripts/test036-meta-concurrency index d430732638..958f7842e3 100755 --- a/tests/scripts/test036-meta-concurrency +++ b/tests/scripts/test036-meta-concurrency @@ -23,25 +23,36 @@ if test $BACKMETA = metano ; then exit 0 fi -if test "x$TEST_META" != "xyes" ; then - echo "### this test is currently disabled;" - echo "### set \"TEST_META=yes\" to enable (at own risk)." +# to be removed some time... +if test "x$TEST_META" = "xno" ; then + echo "### disabled by \"TEST_META=no\"; unset TEST_META to re-enable" + echo "" exit 0 else - echo "### this test is __very__ experimental; enable at own risk" + echo "### this test is experimental; in case of problems," + echo "### set \"TEST_META=no\" to disable, and report thru" + echo "### the Issue Tracking System " + echo "" fi rm -rf $TESTDIR mkdir -p $TESTDIR $DBDIR1 $DBDIR2 -if test "x$DB_CONFIG" != "x" -a -f $DB_CONFIG ; then - echo "==> using DB_CONFIG $DB_CONFIG" - cp $DB_CONFIG $DBDIR1 - cp $DB_CONFIG $DBDIR2 -else - echo "==> set \"DB_CONFIG\" to the location of the DB_CONFIG file" - echo "==> you want to use for the test." +# NOTE: this could be added to all tests... +if test "$BACKEND" = "bdb" -o "$BACKEND" = "hdb" ; then + if test "x$DB_CONFIG" != "x" ; then \ + if test -f $DB_CONFIG ; then + echo "==> using DB_CONFIG \"$DB_CONFIG\"" + cp $DB_CONFIG $DBDIR1 + cp $DB_CONFIG $DBDIR2 + else + echo "==> DB_CONFIG must point to a valid file (ignored)" + fi + else + echo "==> set \"DB_CONFIG\" to the DB_CONFIG file you want to use for the test." + fi + echo "" fi echo "Starting slapd on TCP/IP port $PORT1..." @@ -82,7 +93,7 @@ if test $RC != 0 ; then fi echo "Starting slapd on TCP/IP port $PORT2..." -. $CONFFILTER $BACKEND $MONITORDB < $METACONF > $CONF2 +. $CONFFILTER $BACKEND $MONITORDB < $METACONF2 > $CONF2 $SLAPD -f $CONF2 -h $URI2 -d $LVL $TIMING > $LOG2 2>&1 & PID=$! if test $WAIT != 0 ; then @@ -118,6 +129,33 @@ if test $RC != 0 ; then exit $RC fi +echo "Starting slapd on TCP/IP port $PORT3..." +. $CONFFILTER $BACKEND $MONITORDB < $METACONF > $CONF3 +$SLAPD -f $CONF3 -h $URI3 -d $LVL $TIMING > $LOG3 2>&1 & +PID=$! +if test $WAIT != 0 ; then + echo PID $PID + read foo +fi +KILLPIDS="$KILLPIDS $PID" + +echo "Using ldapsearch to check that slapd is running..." +for i in 0 1 2 3 4 5; do + $LDAPSEARCH -s base -b "$MONITOR" -h $LOCALHOST -p $PORT3 \ + '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 + cat /dev/null > $SEARCHOUT mkdir -p $TESTDIR/$DATADIR @@ -126,12 +164,22 @@ for f in $DATADIR/do_* ; do sed -e "s;$BASEDN;$METABASEDN;" $f > $TESTDIR/$f done +# add a read that matches only the local database, but selects +# also the remote as candidate; this should be removed to compare +# execution times with test008... for f in $TESTDIR/$DATADIR/do_read.* ; do echo "ou=Meta,$METABASEDN" >> $f done +# add a read that matches a referral in the local database only, +# but selects also the remote as candidate; this should be removed +# to compare execution times with test008... +for f in $TESTDIR/$DATADIR/do_read.* ; do + echo "cn=Somewhere,ou=Meta,$METABASEDN" >> $f +done + echo "Using tester for concurrent server access..." -$SLAPDTESTER -P "$PROGDIR" -d "$TESTDIR/$DATADIR" -h $LOCALHOST -p $PORT2 -D "cn=Manager,$METABASEDN" -w $PASSWD -l 100 -r 20 +$SLAPDTESTER -P "$PROGDIR" -d "$TESTDIR/$DATADIR" -h $LOCALHOST -p $PORT3 -D "cn=Manager,$METABASEDN" -w $PASSWD -l 50 # -r 20 RC=$? if test $RC != 0 ; then @@ -141,7 +189,7 @@ if test $RC != 0 ; then fi echo "Using ldapsearch to retrieve all the entries..." -$LDAPSEARCH -S "" -b "$METABASEDN" -h $LOCALHOST -p $PORT2 \ +$LDAPSEARCH -S "" -b "$METABASEDN" -h $LOCALHOST -p $PORT3 \ 'objectClass=*' > $SEARCHOUT 2>&1 RC=$? @@ -158,7 +206,7 @@ echo "Filtering original ldif used to create database..." . $LDIFFILTER < $METACONCURRENCYOUT > $LDIFFLT echo "Comparing filter output..." $CMP $SEARCHFLT $LDIFFLT > $CMPOUT - + if test $? != 0 ; then echo "comparison failed - meta search/modification didn't succeed" exit 1