summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rwxr-xr-xregress/usr.bin/openssl/appstest.sh79
1 files changed, 71 insertions, 8 deletions
diff --git a/regress/usr.bin/openssl/appstest.sh b/regress/usr.bin/openssl/appstest.sh
index ed7332c4b3d..94a7755f3ab 100755
--- a/regress/usr.bin/openssl/appstest.sh
+++ b/regress/usr.bin/openssl/appstest.sh
@@ -1,6 +1,6 @@
#!/bin/sh
#
-# $OpenBSD: appstest.sh,v 1.34 2020/05/14 14:09:11 inoguchi Exp $
+# $OpenBSD: appstest.sh,v 1.35 2020/05/15 13:45:36 inoguchi Exp $
#
# Copyright (c) 2016 Kinichiro Inoguchi <inoguchi@openbsd.org>
#
@@ -733,6 +733,37 @@ revoke.test_dummy.com
__EOF__
check_exit_status $?
+ ecdsa_key=$server_dir/ecdsa_key.pem
+ ecdsa_csr=$server_dir/ecdsa_csr.pem
+ ecdsa_pass=test-ecdsa-pass
+
+ if [ $mingw = 0 ] ; then
+ subj='/C=JP/ST=Tokyo/O=TEST_DUMMY_COMPANY/CN=ecdsa.test_dummy.com/'
+ else
+ subj='//C=JP\ST=Tokyo\O=TEST_DUMMY_COMPANY\CN=ecdsa.test_dummy.com\'
+ fi
+
+ start_message "ecparam ... generate server key#3"
+
+ $openssl_bin ecparam -name prime256v1 -genkey -out $ecdsa_key
+ check_exit_status $?
+
+ start_message "req ... generate server csr#3"
+
+ $openssl_bin req -new -subj $subj -sha256 \
+ -key $ecdsa_key -keyform pem -passin pass:$ecdsa_pass \
+ -addext 'subjectAltName = DNS:localhost.test_dummy.com' \
+ -out $ecdsa_csr -outform pem
+ check_exit_status $?
+
+ start_message "req ... verify server csr#3"
+
+ $openssl_bin req -verify -in $ecdsa_csr -inform pem \
+ -newhdr -noout -pubkey -subject -modulus -text \
+ -nameopt multiline -reqopt compatible \
+ -out $ecdsa_csr.verify.out
+ check_exit_status $?
+
#---------#---------#---------#---------#---------#---------#---------
# --- CA operations (issue cert for server) ---
@@ -754,6 +785,13 @@ __EOF__
-passin pass:$ca_pass -CAcreateserial -out $revoke_cert
check_exit_status $?
+ start_message "ca ... issue cert for server csr#3"
+
+ ecdsa_cert=$server_dir/ecdsa_cert.pem
+ $openssl_bin ca -batch -cert $ca_cert -keyfile $ca_key -key $ca_pass \
+ -in $ecdsa_csr -out $ecdsa_cert
+ check_exit_status $?
+
#---------#---------#---------#---------#---------#---------#---------
# --- CA operations (revoke cert and generate crl) ---
@@ -1328,6 +1366,18 @@ function test_server_client {
sess_dat=$user1_dir/s_client_${sc}_sess.dat
s_server_out=$server_dir/s_server_${sc}_tls.out
+ if [ $ecdsa_tests = 0 ] ; then
+ echo "Using RSA certificate"
+ crt=$server_cert
+ key=$server_key
+ pwd=$server_pass
+ else
+ echo "Using ECDSA certificate"
+ crt=$ecdsa_cert
+ key=$ecdsa_key
+ pwd=$ecdsa_pass
+ fi
+
$s_bin version | grep 'OpenSSL 1.1.1' > /dev/null
if [ $? -eq 0 ] ; then
extra_opts="-4"
@@ -1337,7 +1387,7 @@ function test_server_client {
start_message "s_server ... start TLS/SSL test server"
$s_bin s_server -accept $port -CAfile $ca_cert \
- -cert $server_cert -key $server_key -pass pass:$server_pass \
+ -cert $crt -key $key -pass pass:$pwd \
-context "appstest.sh" -id_prefix "APPSTEST.SH" -crl_check \
-alpn "http/1.1,spdy/3" -www -cipher ALL $extra_opts \
-msg -tlsextdebug > $s_server_out 2>&1 &
@@ -1355,18 +1405,26 @@ function test_server_client {
# all available ciphers with random order
s_ciph=$server_dir/s_ciph_${sc}
+ cipher_string=""
if [ $s_id = "0" ] ; then
- $s_bin ciphers -v ALL:!ECDSA:!kGOST:!TLSv1.3 | awk '{print $1}' > $s_ciph
- else
- $s_bin ciphers -v | awk '{print $1}' > $s_ciph
+ if [ $ecdsa_tests = 0 ] ; then
+ cipher_string="ALL:!ECDSA:!kGOST:!TLSv1.3"
+ else
+ cipher_string="ECDSA+TLSv1.2:!TLSv1.3"
+ fi
fi
+ $s_bin ciphers -v $cipher_string | awk '{print $1}' > $s_ciph
c_ciph=$user1_dir/c_ciph_${sc}
+ cipher_string=""
if [ $c_id = "0" ] ; then
- $c_bin ciphers -v ALL:!ECDSA:!kGOST:!TLSv1.3 | awk '{print $1}' > $c_ciph
- else
- $c_bin ciphers -v | awk '{print $1}' > $c_ciph
+ if [ $ecdsa_tests = 0 ] ; then
+ cipher_string="ALL:!ECDSA:!kGOST:!TLSv1.3"
+ else
+ cipher_string="ECDSA+TLSv1.2:!TLSv1.3"
+ fi
fi
+ $c_bin ciphers -v $cipher_string | awk '{print $1}' > $c_ciph
ciphers=$user1_dir/ciphers_${sc}
grep -x -f $s_ciph $c_ciph | sort -R > $ciphers
@@ -1483,11 +1541,16 @@ function test_version {
openssl_bin=${OPENSSL:-/usr/bin/openssl}
other_openssl_bin=${OTHER_OPENSSL:-/usr/local/bin/eopenssl11}
+ecdsa_tests=0
interop_tests=0
no_long_tests=0
while [ "$1" != "" ]; do
case $1 in
+ -e | --ecdsa)
+ shift
+ ecdsa_tests=1
+ ;;
-i | --interop) shift
interop_tests=1
;;