diff options
Diffstat (limited to 'regress/keytype.sh')
-rw-r--r-- | regress/keytype.sh | 55 |
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 | |||
4 | tid="login with different key types" | ||
5 | |||
6 | TIME=`which time` 2>/dev/null | ||
7 | if test ! -x "$TIME"; then | ||
8 | TIME="" | ||
9 | fi | ||
10 | |||
11 | cp $OBJ/sshd_proxy $OBJ/sshd_proxy_bak | ||
12 | cp $OBJ/ssh_proxy $OBJ/ssh_proxy_bak | ||
13 | |||
14 | ktypes="dsa-1024 rsa-2048 rsa-3072" | ||
15 | if test "$TEST_SSH_ECC" = "yes"; then | ||
16 | ktypes="$ktypes ecdsa-256 ecdsa-384 ecdsa-521" | ||
17 | fi | ||
18 | |||
19 | for 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" | ||
26 | done | ||
27 | |||
28 | tries="1 2 3" | ||
29 | for 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 | ||
55 | done | ||