summaryrefslogtreecommitdiff
path: root/regress/keytype.sh
diff options
context:
space:
mode:
Diffstat (limited to 'regress/keytype.sh')
-rw-r--r--regress/keytype.sh55
1 files changed, 55 insertions, 0 deletions
diff --git a/regress/keytype.sh b/regress/keytype.sh
new file mode 100644
index 000000000..2cbf132bd
--- /dev/null
+++ b/regress/keytype.sh
@@ -0,0 +1,55 @@
1# $OpenBSD: keytype.sh,v 1.1 2010/09/02 16:12:55 markus Exp $
2# Placed in the Public Domain.
3
4tid="login with different key types"
5
6TIME=`which time` 2>/dev/null
7if test ! -x "$TIME"; then
8 TIME=""
9fi
10
11cp $OBJ/sshd_proxy $OBJ/sshd_proxy_bak
12cp $OBJ/ssh_proxy $OBJ/ssh_proxy_bak
13
14ktypes="dsa-1024 rsa-2048 rsa-3072"
15if test "$TEST_SSH_ECC" = "yes"; then
16 ktypes="$ktypes ecdsa-256 ecdsa-384 ecdsa-521"
17fi
18
19for kt in $ktypes; do
20 rm -f $OBJ/key.$kt
21 bits=`echo ${kt} | awk -F- '{print $2}'`
22 type=`echo ${kt} | awk -F- '{print $1}'`
23 printf "keygen $type, $bits bits:\t"
24 ${TIME} ${SSHKEYGEN} -b $bits -q -N '' -t $type -f $OBJ/key.$kt ||\
25 fail "ssh-keygen for type $type, $bits bits failed"
26done
27
28tries="1 2 3"
29for ut in $ktypes; do
30 htypes=$ut
31 #htypes=$ktypes
32 for ht in $htypes; do
33 trace "ssh connect, userkey $ut, hostkey $ht"
34 (
35 grep -v HostKey $OBJ/sshd_proxy_bak
36 echo HostKey $OBJ/key.$ht
37 ) > $OBJ/sshd_proxy
38 (
39 grep -v IdentityFile $OBJ/ssh_proxy_bak
40 echo IdentityFile $OBJ/key.$ut
41 ) > $OBJ/ssh_proxy
42 (
43 echon 'localhost-with-alias,127.0.0.1,::1 '
44 cat $OBJ/key.$ht.pub
45 ) > $OBJ/known_hosts
46 cat $OBJ/key.$ut.pub > $OBJ/authorized_keys_$USER
47 for i in $tries; do
48 printf "userkey $ut, hostkey ${ht}:\t"
49 ${TIME} ${SSH} -F $OBJ/ssh_proxy 999.999.999.999 true
50 if [ $? -ne 0 ]; then
51 fail "ssh userkey $ut, hostkey $ht failed"
52 fi
53 done
54 done
55done