2016-08-21 01:51:14 +08:00
|
|
|
# -*- mode: perl; -*-
|
|
|
|
|
|
|
|
## SSL test configurations
|
|
|
|
|
|
|
|
package ssltests;
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
|
|
|
|
use OpenSSL::Test;
|
|
|
|
use OpenSSL::Test::Utils qw(anydisabled);
|
|
|
|
|
2020-04-08 00:03:19 +08:00
|
|
|
our $fips_mode;
|
|
|
|
|
2021-02-12 01:18:49 +08:00
|
|
|
my @curves = ("prime256v1", "secp384r1", "secp521r1", "X25519",
|
2020-04-08 00:03:19 +08:00
|
|
|
"X448");
|
2022-09-30 20:35:28 +08:00
|
|
|
#Curves *only* suitable for use in TLSv1.3
|
2023-06-23 23:01:41 +08:00
|
|
|
my @curves_tls_1_3 = ("ffdhe2048", "ffdhe3072", "ffdhe4096", "ffdhe6144",
|
|
|
|
"ffdhe8192");
|
|
|
|
my @curves_tls_1_3_no_fips = ("brainpoolP256r1tls13", "brainpoolP384r1tls13",
|
|
|
|
"brainpoolP512r1tls13");
|
2022-09-30 20:35:28 +08:00
|
|
|
|
2023-06-23 23:01:41 +08:00
|
|
|
push @curves_tls_1_3, @curves_tls_1_3_no_fips if !$fips_mode;
|
|
|
|
push @curves, @curves_tls_1_3;
|
2020-04-08 00:03:19 +08:00
|
|
|
|
2021-02-12 01:18:49 +08:00
|
|
|
my @curves_tls_1_2 = ("sect233k1", "sect233r1",
|
|
|
|
"sect283k1", "sect283r1", "sect409k1", "sect409r1",
|
|
|
|
"sect571k1", "sect571r1", "secp224r1");
|
|
|
|
|
2020-08-29 10:59:04 +08:00
|
|
|
my @curves_non_fips = ("sect163k1", "sect163r2", "prime192v1",
|
|
|
|
"sect163r1", "sect193r1", "sect193r2", "sect239k1",
|
2020-04-08 00:03:19 +08:00
|
|
|
"secp160k1", "secp160r1", "secp160r2", "secp192k1",
|
|
|
|
"secp224k1", "secp256k1", "brainpoolP256r1",
|
|
|
|
"brainpoolP384r1", "brainpoolP512r1");
|
|
|
|
|
2021-02-12 01:18:49 +08:00
|
|
|
push @curves_tls_1_2, @curves_non_fips if !$fips_mode;
|
2016-08-21 01:51:14 +08:00
|
|
|
|
|
|
|
our @tests = ();
|
|
|
|
|
2023-06-23 23:01:41 +08:00
|
|
|
sub get_key_type {
|
|
|
|
my $group = shift;
|
|
|
|
my $keyType;
|
|
|
|
|
|
|
|
if ($group =~ /ffdhe/) {
|
|
|
|
$keyType = "dhKeyAgreement";
|
|
|
|
} else {
|
|
|
|
$keyType = $group;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $keyType;
|
|
|
|
}
|
|
|
|
|
2016-08-21 01:51:14 +08:00
|
|
|
sub generate_tests() {
|
|
|
|
foreach (0..$#curves) {
|
|
|
|
my $curve = $curves[$_];
|
|
|
|
push @tests, {
|
2017-04-26 17:38:32 +08:00
|
|
|
name => "curve-${curve}",
|
2016-08-21 01:51:14 +08:00
|
|
|
server => {
|
2016-10-22 00:39:33 +08:00
|
|
|
"Curves" => $curve,
|
2021-10-06 00:30:09 +08:00
|
|
|
"CipherString" => 'DEFAULT@SECLEVEL=1',
|
2021-02-12 01:18:49 +08:00
|
|
|
"MaxProtocol" => "TLSv1.3"
|
|
|
|
},
|
|
|
|
client => {
|
2021-10-06 00:30:09 +08:00
|
|
|
"CipherString" => 'ECDHE@SECLEVEL=1',
|
2021-02-12 01:18:49 +08:00
|
|
|
"MaxProtocol" => "TLSv1.3",
|
|
|
|
"Curves" => $curve
|
|
|
|
},
|
|
|
|
test => {
|
2023-06-23 23:01:41 +08:00
|
|
|
"ExpectedTmpKeyType" => get_key_type($curve),
|
2021-02-12 01:18:49 +08:00
|
|
|
"ExpectedProtocol" => "TLSv1.3",
|
|
|
|
"ExpectedResult" => "Success"
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|
|
|
|
foreach (0..$#curves_tls_1_2) {
|
|
|
|
my $curve = $curves_tls_1_2[$_];
|
|
|
|
push @tests, {
|
|
|
|
name => "curve-${curve}",
|
|
|
|
server => {
|
|
|
|
"Curves" => $curve,
|
2021-10-06 00:30:09 +08:00
|
|
|
"CipherString" => 'DEFAULT@SECLEVEL=1',
|
2021-02-12 01:18:49 +08:00
|
|
|
"MaxProtocol" => "TLSv1.3"
|
2016-08-21 01:51:14 +08:00
|
|
|
},
|
|
|
|
client => {
|
2021-10-06 00:30:09 +08:00
|
|
|
"CipherString" => 'ECDHE@SECLEVEL=1',
|
2017-04-26 17:38:32 +08:00
|
|
|
"MaxProtocol" => "TLSv1.2",
|
2016-08-21 01:51:14 +08:00
|
|
|
"Curves" => $curve
|
|
|
|
},
|
2017-01-09 03:36:20 +08:00
|
|
|
test => {
|
2023-06-23 23:01:41 +08:00
|
|
|
"ExpectedTmpKeyType" => get_key_type($curve),
|
2021-02-12 01:18:49 +08:00
|
|
|
"ExpectedProtocol" => "TLSv1.2",
|
2017-01-09 03:36:20 +08:00
|
|
|
"ExpectedResult" => "Success"
|
|
|
|
},
|
2016-08-21 01:51:14 +08:00
|
|
|
};
|
|
|
|
}
|
2022-09-30 23:59:05 +08:00
|
|
|
foreach (0..$#curves_tls_1_2) {
|
|
|
|
my $curve = $curves_tls_1_2[$_];
|
|
|
|
push @tests, {
|
|
|
|
name => "curve-${curve}-tls12-in-tls13",
|
|
|
|
server => {
|
|
|
|
"Curves" => "$curve:P-256",
|
|
|
|
"CipherString" => 'DEFAULT@SECLEVEL=1',
|
|
|
|
"MaxProtocol" => "TLSv1.3"
|
|
|
|
},
|
|
|
|
client => {
|
|
|
|
"CipherString" => 'ECDHE@SECLEVEL=1',
|
|
|
|
"MaxProtocol" => "TLSv1.3",
|
|
|
|
"MinProtocol" => "TLSv1.3",
|
|
|
|
"Curves" => "$curve:P-256"
|
|
|
|
},
|
|
|
|
test => {
|
|
|
|
#This curve is not allowed in a TLSv1.3 key_share. We should
|
|
|
|
#succeed but fallback to P-256
|
|
|
|
"ExpectedTmpKeyType" => "P-256",
|
|
|
|
"ExpectedProtocol" => "TLSv1.3",
|
|
|
|
"ExpectedResult" => "Success"
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|
2021-02-12 01:18:49 +08:00
|
|
|
foreach (0..$#curves_tls_1_2) {
|
|
|
|
my $curve = $curves_tls_1_2[$_];
|
|
|
|
push @tests, {
|
|
|
|
name => "curve-${curve}-tls13",
|
|
|
|
server => {
|
|
|
|
"Curves" => $curve,
|
2021-10-06 00:30:09 +08:00
|
|
|
"CipherString" => 'DEFAULT@SECLEVEL=1',
|
2021-02-12 01:18:49 +08:00
|
|
|
"MaxProtocol" => "TLSv1.3"
|
|
|
|
},
|
|
|
|
client => {
|
2021-10-06 00:30:09 +08:00
|
|
|
"CipherString" => 'ECDHE@SECLEVEL=1',
|
2021-02-12 01:18:49 +08:00
|
|
|
"MinProtocol" => "TLSv1.3",
|
|
|
|
"Curves" => $curve
|
|
|
|
},
|
|
|
|
test => {
|
|
|
|
"ExpectedResult" => "ClientFail"
|
|
|
|
},
|
|
|
|
};
|
|
|
|
}
|
2023-06-23 23:01:41 +08:00
|
|
|
foreach (0..$#curves_tls_1_3) {
|
|
|
|
my $curve = $curves_tls_1_3[$_];
|
|
|
|
push @tests, {
|
|
|
|
name => "curve-${curve}-tls13-in-tls12",
|
|
|
|
server => {
|
|
|
|
"Curves" => $curve,
|
|
|
|
"CipherString" => 'DEFAULT@SECLEVEL=1',
|
|
|
|
"MaxProtocol" => "TLSv1.3"
|
|
|
|
},
|
|
|
|
client => {
|
|
|
|
"CipherString" => 'ECDHE@SECLEVEL=1',
|
|
|
|
"MaxProtocol" => "TLSv1.2",
|
|
|
|
"Curves" => $curve
|
|
|
|
},
|
|
|
|
test => {
|
|
|
|
#These curves are only suitable for TLSv1.3 so we expect the
|
|
|
|
#server to fail because it has no shared groups for TLSv1.2
|
|
|
|
#ECDHE key exchange
|
|
|
|
"ExpectedResult" => "ServerFail"
|
|
|
|
},
|
|
|
|
};
|
|
|
|
push @tests, {
|
|
|
|
name => "curve-${curve}-tls13-in-tls12-2",
|
|
|
|
server => {
|
|
|
|
"Curves" => $curve,
|
|
|
|
"CipherString" => 'DEFAULT@SECLEVEL=1',
|
|
|
|
"MaxProtocol" => "TLSv1.2"
|
|
|
|
},
|
|
|
|
client => {
|
|
|
|
"CipherString" => 'DEFAULT@SECLEVEL=1',
|
|
|
|
"MaxProtocol" => "TLSv1.3",
|
|
|
|
"Curves" => $curve
|
|
|
|
},
|
|
|
|
test => {
|
|
|
|
#These curves are only suitable for TLSv1.3. We expect TLSv1.2
|
|
|
|
#negotiation to succeed because we fall back to some other
|
|
|
|
#ciphersuite
|
|
|
|
"ExpectedResult" => "Success"
|
|
|
|
},
|
|
|
|
};
|
2022-09-30 20:35:28 +08:00
|
|
|
}
|
2016-08-21 01:51:14 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
generate_tests();
|