42 lines
1.0 KiB
Bash
42 lines
1.0 KiB
Bash
# $OpenBSD: agent-timeout.sh,v 1.5 2019/09/03 08:37:06 djm Exp $
|
|
# Placed in the Public Domain.
|
|
|
|
tid="agent timeout test"
|
|
if [ "$os" == "windows" ]; then
|
|
echo "skipped (not supported on WINDOWS platform)"
|
|
exit 0
|
|
fi
|
|
SSHAGENT_TIMEOUT=10
|
|
|
|
trace "start agent"
|
|
eval `${SSHAGENT} -s` > /dev/null
|
|
r=$?
|
|
if [ $r -ne 0 ]; then
|
|
fail "could not start ssh-agent: exit code $r"
|
|
else
|
|
trace "add keys with timeout"
|
|
keys=0
|
|
for t in ${SSH_KEYTYPES}; do
|
|
${SSHADD} -kt ${SSHAGENT_TIMEOUT} $OBJ/$t > /dev/null 2>&1
|
|
if [ $? -ne 0 ]; then
|
|
fail "ssh-add did succeed exit code 0"
|
|
fi
|
|
keys=$((${keys} + 1))
|
|
done
|
|
n=`${SSHADD} -l 2> /dev/null | wc -l`
|
|
trace "agent has $n keys"
|
|
if [ $n -ne $keys ]; then
|
|
fail "ssh-add -l did not return $keys keys: $n"
|
|
fi
|
|
trace "sleeping 2*${SSHAGENT_TIMEOUT} seconds"
|
|
sleep ${SSHAGENT_TIMEOUT}
|
|
sleep ${SSHAGENT_TIMEOUT}
|
|
${SSHADD} -l 2> /dev/null | grep 'The agent has no identities.' >/dev/null
|
|
if [ $? -ne 0 ]; then
|
|
fail "ssh-add -l still returns keys after timeout"
|
|
fi
|
|
|
|
trace "kill agent"
|
|
${SSHAGENT} -k > /dev/null
|
|
fi
|