]> git.ipfire.org Git - thirdparty/openldap.git/commitdiff
ITS#9156 Add some ppolicy v10 tests
authorOndřej Kuzník <ondra@mistotebe.net>
Thu, 24 Oct 2019 13:14:05 +0000 (14:14 +0100)
committerOndřej Kuzník <ondra@mistotebe.net>
Thu, 23 Jan 2020 23:47:09 +0000 (23:47 +0000)
tests/data/ppolicy.ldif
tests/data/slapd-ppolicy.conf
tests/scripts/test022-ppolicy

index fdd0c48be1956f40d124c6e56b8492d43a77c89a..d4d697dd48b76a64473d132eb17f8539e5f3ad6a 100644 (file)
@@ -27,6 +27,7 @@ pwdCheckQuality: 2
 pwdExpireWarning: 10
 pwdMaxAge: 30
 pwdMinLength: 5
+pwdMaxLength: 13
 pwdGraceAuthnLimit: 3
 pwdAllowUserChange: TRUE
 pwdMustChange: TRUE
index 5895120b958c647fc8610e7ec07aad3a6dcd6ae4..ed47fe5dc051e45e6c88dcf5b362866891ac22c6 100644 (file)
@@ -39,6 +39,8 @@ rootpw                secret
 #ndb#dbname db_1
 #ndb#include @DATADIR@/ndb.conf
 
+lastbind on
+
 overlay                ppolicy
 ppolicy_default        "cn=Standard Policy,ou=Policies,dc=example,dc=com"
 ppolicy_use_lockout
index 904497832b191faf0f92e4a5776d3ffde5d023f1..5a7bdbe5e97146f90f31b89626731d34be39957b 100755 (executable)
@@ -329,6 +329,18 @@ if test $COUNT != 1 ; then
        exit 1
 fi
 
+$LDAPPASSWD -h $LOCALHOST -p $PORT1 \
+       -w $PASS -a $PASS -s passwordthatistoolong \
+       -D "$USER" -e ppolicy > ${TESTOUT}.2 2>&1
+RC=$?
+cat ${TESTOUT}.2 >> $TESTOUT
+COUNT=`grep "Password is too long for policy" ${TESTOUT}.2 | wc -l`
+if test $COUNT != 1 ; then
+       echo "Control not returned in response"
+       test $KILLSERVERS != no && kill -HUP $KILLPIDS
+       exit 1
+fi
+
 echo "Testing hashed length requirement..."
 
 $LDAPMODIFY -h $LOCALHOST -p $PORT1 -D "$USER" -w $PASS > \
@@ -405,6 +417,58 @@ if test $RC = 0 ; then
        exit 1
 fi
 
+echo "Testing idle password expiration"
+echo "Reconfiguring policy to replace expiration with idle expiration..."
+$LDAPMODIFY -v -D "$MANAGERDN" -h $LOCALHOST -p $PORT1 -w $PASSWD >> \
+       $TESTOUT 2>&1 << EOMODS
+dn: cn=Standard Policy, ou=Policies, dc=example, dc=com
+changetype: modify
+delete: pwdMaxAge
+-
+add: pwdMaxIdle
+pwdMaxIdle: 15
+
+EOMODS
+RC=$?
+if test $RC != 0 ; then
+       echo "ldapmodify failed ($RC)!"
+       test $KILLSERVERS != no && kill -HUP $KILLPIDS
+       exit $RC
+fi
+
+$LDAPSEARCH -e ppolicy -h $LOCALHOST -p $PORT1 -D "$USER" -w $PASS \
+       -b "$BASEDN" -s base > $SEARCHOUT 2>&1
+
+echo "Waiting 20 seconds for password to expire..."
+sleep 20
+
+$LDAPSEARCH -e ppolicy -h $LOCALHOST -p $PORT1 -D "$USER" -w $PASS \
+       -b "$BASEDN" -s base >> $SEARCHOUT 2>&1
+RC=$?
+if test $RC != 49 ; then
+       echo "Password idle expiration failed ($RC)!"
+       test $KILLSERVERS != no && kill -HUP $KILLPIDS
+       exit 1
+fi
+
+echo "Reverting policy changes..."
+$LDAPMODIFY -v -D "$MANAGERDN" -h $LOCALHOST -p $PORT1 -w $PASSWD >> \
+       $TESTOUT 2>&1 << EOMODS
+dn: cn=Standard Policy, ou=Policies, dc=example, dc=com
+changetype: modify
+delete: pwdMaxIdle
+-
+add: pwdMaxAge
+pwdMaxAge: 30
+
+EOMODS
+RC=$?
+if test $RC != 0 ; then
+       echo "ldapmodify failed ($RC)!"
+       test $KILLSERVERS != no && kill -HUP $KILLPIDS
+       exit $RC
+fi
+
 if test "$BACKLDAP" != "ldapno" && test "$SYNCPROV" != "syncprovno"  ; then 
 echo ""
 echo "Setting up policy state forwarding test..."