upstream: Make sure puttygen is new enough to successfully run the

PuTTY interop tests, otherwise skip them.

OpenBSD-Regress-ID: 34565bb50b8aec58331ed02a5e9e0a9a929bef51
This commit is contained in:
dtucker@openbsd.org 2021-02-17 03:59:00 +00:00 committed by Darren Tucker
parent da0a9afcc4
commit 64bbd7444d
1 changed files with 9 additions and 10 deletions

View File

@ -1,4 +1,4 @@
# $OpenBSD: test-exec.sh,v 1.76 2020/04/04 23:04:41 dtucker Exp $ # $OpenBSD: test-exec.sh,v 1.77 2021/02/17 03:59:00 dtucker Exp $
# Placed in the Public Domain. # Placed in the Public Domain.
#SUDO=sudo #SUDO=sudo
@ -601,10 +601,11 @@ if test -x "$CONCH" ; then
REGRESS_INTEROP_CONCH=yes REGRESS_INTEROP_CONCH=yes
fi fi
# If PuTTY is present and we are running a PuTTY test, prepare keys and # If PuTTY is present, new enough and we are running a PuTTY test, prepare
# configuration # keys and configuration.
REGRESS_INTEROP_PUTTY=no REGRESS_INTEROP_PUTTY=no
if test -x "$PUTTYGEN" -a -x "$PLINK" ; then if test -x "$PUTTYGEN" -a -x "$PLINK" &&
"$PUTTYGEN" --help 2>&1 | grep -- --new-passphrase >/dev/null; then
REGRESS_INTEROP_PUTTY=yes REGRESS_INTEROP_PUTTY=yes
fi fi
case "$SCRIPT" in case "$SCRIPT" in
@ -617,13 +618,13 @@ if test "$REGRESS_INTEROP_PUTTY" = "yes" ; then
# Add a PuTTY key to authorized_keys # Add a PuTTY key to authorized_keys
rm -f ${OBJ}/putty.rsa2 rm -f ${OBJ}/putty.rsa2
if ! puttygen -t rsa -o ${OBJ}/putty.rsa2 \ if ! "$PUTTYGEN" -t rsa -o ${OBJ}/putty.rsa2 \
--random-device=/dev/urandom \ --random-device=/dev/urandom \
--new-passphrase /dev/null < /dev/null > /dev/null; then --new-passphrase /dev/null < /dev/null > /dev/null; then
echo "Your installed version of PuTTY is too old to support --new-passphrase; trying without (may require manual interaction) ..." >&2 echo "Your installed version of PuTTY is too old to support --new-passphrase, skipping test" >&2
puttygen -t rsa -o ${OBJ}/putty.rsa2 < /dev/null > /dev/null exit 1
fi fi
puttygen -O public-openssh ${OBJ}/putty.rsa2 \ "$PUTTYGEN" -O public-openssh ${OBJ}/putty.rsa2 \
>> $OBJ/authorized_keys_$USER >> $OBJ/authorized_keys_$USER
# Convert rsa2 host key to PuTTY format # Convert rsa2 host key to PuTTY format
@ -647,8 +648,6 @@ if test "$REGRESS_INTEROP_PUTTY" = "yes" ; then
PUTTYDIR=${OBJ}/.putty PUTTYDIR=${OBJ}/.putty
export PUTTYDIR export PUTTYDIR
REGRESS_INTEROP_PUTTY=yes
fi fi
# create a proxy version of the client config # create a proxy version of the client config