#! /bin/sh # $OpenLDAP$ ## This work is part of OpenLDAP Software . ## ## Copyright 2021 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 ## . echo "running defines.sh" . $SRCDIR/scripts/defines.sh if test $HOMEDIR = homedirno; then echo "Homedir overlay not available, test skipped" exit 0 fi mkdir -p $TESTDIR $DBDIR1 $TESTDIR/home $TESTDIR/archive $SLAPPASSWD -g -n >$CONFIGPWF echo "rootpw `$SLAPPASSWD -T $CONFIGPWF`" >$TESTDIR/configpw.conf echo "Running slapadd to build slapd database..." . $CONFFILTER $BACKEND < $HOMEDIRCONF | sed "s/@MINUID@/`id -u`/" > $CONF1 $SLAPADD -f $CONF1 -l $LDIF RC=$? if test $RC != 0 ; then echo "slapadd failed ($RC)!" exit $RC fi echo "Starting slapd on TCP/IP port $PORT1..." $SLAPD -f $CONF1 -h $URI1 -d $LVL > $LOG1 2>&1 & PID=$! if test $WAIT != 0 ; then echo PID $PID read foo fi KILLPIDS="$PID" sleep 1 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 $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 "Adding a new user..." $LDAPADD -D "$MANAGERDN" -H $URI1 -w $PASSWD <> $TESTOUT 2>&1 dn: uid=user1,ou=People,$BASEDN objectClass: account objectClass: posixAccount uid: user1 cn: One user uidNumber: `id -u` gidNumber: `id -g` homeDirectory: /home/user1 EOMOD RC=$? if test $RC != 0 ; then echo "ldapadd failed ($RC)!" test $KILLSERVERS != no && kill -HUP $KILLPIDS exit $RC fi sleep 1 if ! test -e $TESTDIR/home/user1 ; then echo "Home directory for user1 not created!" test $KILLSERVERS != no && kill -HUP $KILLPIDS exit 1 fi echo "Moving home directory for user1..." $LDAPMODIFY -D "$MANAGERDN" -H $URI1 -w $PASSWD <> $TESTOUT 2>&1 dn: uid=user1,ou=People,$BASEDN changetype: modify replace: homeDirectory homeDirectory: /home/user1_new EOMOD RC=$? if test $RC != 0 ; then echo "ldapadd failed ($RC)!" test $KILLSERVERS != no && kill -HUP $KILLPIDS exit $RC fi sleep 1 if test -e $TESTDIR/home/user1 || ! test -e $TESTDIR/home/user1_new ; then echo "Home directory for user1 not moved!" test $KILLSERVERS != no && kill -HUP $KILLPIDS exit 1 fi echo "Removing user1, should get archived..." $LDAPDELETE -D "$MANAGERDN" -H $URI1 -w $PASSWD \ "uid=user1,ou=People,$BASEDN" >> $TESTOUT RC=$? if test $RC != 0 ; then echo "ldapdelete failed ($RC)!" test $KILLSERVERS != no && kill -HUP $KILLPIDS exit $RC fi sleep 1 if test -e $TESTDIR/home/user1_new || \ ! test -e $TESTDIR/archive/user1_new-*-0.tar ; then echo "Home directory for user1 not archived properly!" test $KILLSERVERS != no && kill -HUP $KILLPIDS exit 1 fi test $KILLSERVERS != no && kill -HUP $KILLPIDS test $KILLSERVERS != no && wait echo ">>>>> Test succeeded" exit 0