Markus Minichmayr b8590b2f36 Add option `SSL_OP_PREFER_NO_DHE_KEX`, allowing the server to prefer non-dhe psk key exchange over psk with dhe (config file option `PreferNoDHEKEX`, server option `prefer_no_dhe_kex`). | hai 11 meses | |
---|---|---|
.. | ||
certs | hai 1 ano | |
ct | %!s(int64=3) %!d(string=hai) anos | |
d2i-tests | %!s(int64=8) %!d(string=hai) anos | |
helpers | hai 1 ano | |
ocsp-tests | %!s(int64=7) %!d(string=hai) anos | |
recipes | hai 11 meses | |
smime-certs | hai 1 ano | |
smime-eml | hai 1 ano | |
ssl-tests | hai 1 ano | |
testutil | hai 1 ano | |
CAtsa.cnf | hai 1 ano | |
README-dev.md | hai 1 ano | |
README-external.md | hai 1 ano | |
README.md | hai 1 ano | |
README.ssltest.md | %!s(int64=2) %!d(string=hai) anos | |
aborttest.c | %!s(int64=6) %!d(string=hai) anos | |
acvp_test.c | %!s(int64=2) %!d(string=hai) anos | |
acvp_test.inc | %!s(int64=3) %!d(string=hai) anos | |
aesgcmtest.c | %!s(int64=2) %!d(string=hai) anos | |
afalgtest.c | hai 1 ano | |
algorithmid_test.c | %!s(int64=3) %!d(string=hai) anos | |
asn1_decode_test.c | %!s(int64=3) %!d(string=hai) anos | |
asn1_dsa_internal_test.c | %!s(int64=4) %!d(string=hai) anos | |
asn1_encode_test.c | %!s(int64=3) %!d(string=hai) anos | |
asn1_internal_test.c | hai 1 ano | |
asn1_string_table_test.c | %!s(int64=6) %!d(string=hai) anos | |
asn1_time_test.c | %!s(int64=2) %!d(string=hai) anos | |
asynciotest.c | %!s(int64=4) %!d(string=hai) anos | |
asynctest.c | %!s(int64=2) %!d(string=hai) anos | |
bad_dtls_test.c | %!s(int64=2) %!d(string=hai) anos | |
bftest.c | %!s(int64=3) %!d(string=hai) anos | |
bio_addr_test.c | hai 1 ano | |
bio_callback_test.c | %!s(int64=3) %!d(string=hai) anos | |
bio_comp_test.c | %!s(int64=2) %!d(string=hai) anos | |
bio_core_test.c | hai 1 ano | |
bio_dgram_test.c | hai 1 ano | |
bio_enc_test.c | %!s(int64=2) %!d(string=hai) anos | |
bio_memleak_test.c | hai 1 ano | |
bio_prefix_text.c | %!s(int64=3) %!d(string=hai) anos | |
bio_readbuffer_test.c | %!s(int64=3) %!d(string=hai) anos | |
bio_tfo_test.c | %!s(int64=2) %!d(string=hai) anos | |
bioprinttest.c | %!s(int64=4) %!d(string=hai) anos | |
bn_internal_test.c | %!s(int64=3) %!d(string=hai) anos | |
bn_rand_range.h | %!s(int64=5) %!d(string=hai) anos | |
bntest.c | hai 1 ano | |
bntests.pl | %!s(int64=6) %!d(string=hai) anos | |
build.info | hai 11 meses | |
build_wincrypt_test.c | hai 1 ano | |
ca-and-certs.cnf | hai 1 ano | |
ca_internals_test.c | %!s(int64=2) %!d(string=hai) anos | |
casttest.c | %!s(int64=4) %!d(string=hai) anos | |
cc_dummy.c | hai 1 ano | |
cert_comp_test.c | %!s(int64=2) %!d(string=hai) anos | |
chacha_internal_test.c | hai 1 ano | |
cipher_overhead_test.c | %!s(int64=3) %!d(string=hai) anos | |
cipherbytes_test.c | %!s(int64=4) %!d(string=hai) anos | |
cipherlist_test.c | %!s(int64=3) %!d(string=hai) anos | |
ciphername_test.c | %!s(int64=4) %!d(string=hai) anos | |
clienthellotest.c | %!s(int64=3) %!d(string=hai) anos | |
cmactest.c | hai 1 ano | |
cmp_asn_test.c | hai 1 ano | |
cmp_client_test.c | hai 1 ano | |
cmp_ctx_test.c | hai 1 ano | |
cmp_hdr_test.c | hai 1 ano | |
cmp_msg_test.c | hai 1 ano | |
cmp_protect_test.c | hai 1 ano | |
cmp_server_test.c | %!s(int64=3) %!d(string=hai) anos | |
cmp_status_test.c | hai 1 ano | |
cmp_vfy_test.c | hai 1 ano | |
cms-examples.pl | %!s(int64=6) %!d(string=hai) anos | |
cmsapitest.c | hai 1 ano | |
conf_include_test.c | hai 1 ano | |
confdump.c | %!s(int64=3) %!d(string=hai) anos | |
constant_time_test.c | %!s(int64=3) %!d(string=hai) anos | |
context_internal_test.c | %!s(int64=2) %!d(string=hai) anos | |
crltest.c | %!s(int64=2) %!d(string=hai) anos | |
ct_test.c | %!s(int64=2) %!d(string=hai) anos | |
ctype_internal_test.c | %!s(int64=5) %!d(string=hai) anos | |
curve448_internal_test.c | hai 1 ano | |
d2i_test.c | %!s(int64=4) %!d(string=hai) anos | |
dane-cross.in | %!s(int64=2) %!d(string=hai) anos | |
danetest.c | %!s(int64=2) %!d(string=hai) anos | |
danetest.in | %!s(int64=6) %!d(string=hai) anos | |
danetest.pem | %!s(int64=8) %!d(string=hai) anos | |
data.bin | %!s(int64=4) %!d(string=hai) anos | |
data2.bin | %!s(int64=3) %!d(string=hai) anos | |
decoder_propq_test.c | hai 1 ano | |
default-and-fips.cnf | %!s(int64=3) %!d(string=hai) anos | |
default-and-legacy.cnf | %!s(int64=3) %!d(string=hai) anos | |
default.cnf | %!s(int64=3) %!d(string=hai) anos | |
defltfips_test.c | %!s(int64=2) %!d(string=hai) anos | |
destest.c | hai 1 ano | |
dhkem_test.inc | hai 1 ano | |
dhtest.c | hai 1 ano | |
drbgtest.c | hai 1 ano | |
dsa_no_digest_size_test.c | %!s(int64=4) %!d(string=hai) anos | |
dsatest.c | hai 1 ano | |
dtls_mtu_test.c | %!s(int64=2) %!d(string=hai) anos | |
dtlstest.c | hai 1 ano | |
dtlsv1listentest.c | %!s(int64=6) %!d(string=hai) anos | |
ec_internal_test.c | %!s(int64=2) %!d(string=hai) anos | |
ecdsatest.c | hai 1 ano | |
ecdsatest.h | %!s(int64=5) %!d(string=hai) anos | |
ecstresstest.c | %!s(int64=3) %!d(string=hai) anos | |
ectest.c | hai 1 ano | |
endecode_test.c | hai 1 ano | |
endecoder_legacy_test.c | %!s(int64=3) %!d(string=hai) anos | |
enginetest.c | %!s(int64=2) %!d(string=hai) anos | |
errtest.c | hai 1 ano | |
event_queue_test.c | %!s(int64=2) %!d(string=hai) anos | |
evp_extra_test.c | hai 1 ano | |
evp_extra_test2.c | hai 1 ano | |
evp_fetch_prov_test.c | %!s(int64=2) %!d(string=hai) anos | |
evp_kdf_test.c | hai 1 ano | |
evp_libctx_test.c | %!s(int64=2) %!d(string=hai) anos | |
evp_pkey_ctx_new_from_name.c | %!s(int64=2) %!d(string=hai) anos | |
evp_pkey_dhkem_test.c | hai 1 ano | |
evp_pkey_dparams_test.c | %!s(int64=2) %!d(string=hai) anos | |
evp_pkey_provided_test.c | hai 1 ano | |
evp_test.c | hai 1 ano | |
evp_xof_test.c | hai 1 ano | |
exdatatest.c | %!s(int64=3) %!d(string=hai) anos | |
exptest.c | hai 1 ano | |
ext_internal_test.c | hai 1 ano | |
fake_rsaprov.c | hai 1 ano | |
fake_rsaprov.h | hai 1 ano | |
fatalerrtest.c | %!s(int64=4) %!d(string=hai) anos | |
ffc_internal_test.c | hai 1 ano | |
filterprov.c | hai 1 ano | |
filterprov.h | %!s(int64=3) %!d(string=hai) anos | |
fips-alt.cnf | %!s(int64=3) %!d(string=hai) anos | |
fips-and-base.cnf | hai 1 ano | |
fips.cnf | %!s(int64=3) %!d(string=hai) anos | |
fips_version_test.c | %!s(int64=2) %!d(string=hai) anos | |
generate_buildtest.pl | %!s(int64=6) %!d(string=hai) anos | |
generate_ssl_tests.pl | %!s(int64=3) %!d(string=hai) anos | |
gmdifftest.c | %!s(int64=3) %!d(string=hai) anos | |
hexstr_test.c | %!s(int64=3) %!d(string=hai) anos | |
hmactest.c | %!s(int64=2) %!d(string=hai) anos | |
hpke_test.c | hai 1 ano | |
http_test.c | %!s(int64=2) %!d(string=hai) anos | |
ideatest.c | %!s(int64=4) %!d(string=hai) anos | |
igetest.c | %!s(int64=5) %!d(string=hai) anos | |
insta.priv.pem | %!s(int64=3) %!d(string=hai) anos | |
insta_ca.cert.pem | %!s(int64=3) %!d(string=hai) anos | |
keymgmt_internal_test.c | hai 1 ano | |
legacy.cnf | %!s(int64=3) %!d(string=hai) anos | |
lhash_test.c | %!s(int64=2) %!d(string=hai) anos | |
list_test.c | %!s(int64=2) %!d(string=hai) anos | |
localetest.c | %!s(int64=2) %!d(string=hai) anos | |
mdc2_internal_test.c | %!s(int64=4) %!d(string=hai) anos | |
mdc2test.c | hai 1 ano | |
membio_test.c | hai 1 ano | |
memleaktest.c | %!s(int64=3) %!d(string=hai) anos | |
modes_internal_test.c | %!s(int64=3) %!d(string=hai) anos | |
moduleloadtest.c | %!s(int64=3) %!d(string=hai) anos | |
namemap_internal_test.c | %!s(int64=3) %!d(string=hai) anos | |
nodefltctxtest.c | hai 1 ano | |
null.cnf | hai 1 ano | |
ocspapitest.c | hai 1 ano | |
ossl_store_test.c | %!s(int64=3) %!d(string=hai) anos | |
p_test.c | hai 1 ano | |
packettest.c | hai 1 ano | |
pairwise_fail_test.c | hai 1 ano | |
param_build_test.c | hai 1 ano | |
params_api_test.c | %!s(int64=2) %!d(string=hai) anos | |
params_conversion_test.c | %!s(int64=2) %!d(string=hai) anos | |
params_test.c | %!s(int64=2) %!d(string=hai) anos | |
pbelutest.c | %!s(int64=6) %!d(string=hai) anos | |
pbetest.c | hai 1 ano | |
pem_read_depr_test.c | %!s(int64=3) %!d(string=hai) anos | |
pemtest.c | hai 1 ano | |
pkcs12_api_test.c | hai 1 ano | |
pkcs12_format_test.c | hai 1 ano | |
pkcs7-1.pem | %!s(int64=26) %!d(string=hai) anos | |
pkcs7.pem | %!s(int64=26) %!d(string=hai) anos | |
pkcs7_test.c | %!s(int64=3) %!d(string=hai) anos | |
pkey_meth_kdf_test.c | %!s(int64=4) %!d(string=hai) anos | |
pkey_meth_test.c | %!s(int64=4) %!d(string=hai) anos | |
pkits-test.pl | %!s(int64=6) %!d(string=hai) anos | |
poly1305_internal_test.c | %!s(int64=5) %!d(string=hai) anos | |
priority_queue_test.c | hai 1 ano | |
property_test.c | hai 1 ano | |
prov_config_test.c | %!s(int64=3) %!d(string=hai) anos | |
provfetchtest.c | hai 1 ano | |
provider_default_search_path_test.c | hai 1 ano | |
provider_fallback_test.c | %!s(int64=3) %!d(string=hai) anos | |
provider_internal_test.c | hai 1 ano | |
provider_internal_test.cnf.in | %!s(int64=3) %!d(string=hai) anos | |
provider_pkey_test.c | hai 1 ano | |
provider_status_test.c | %!s(int64=3) %!d(string=hai) anos | |
provider_test.c | hai 1 ano | |
proxy.cnf | %!s(int64=3) %!d(string=hai) anos | |
punycode_test.c | hai 1 ano | |
quic_ackm_test.c | hai 1 ano | |
quic_cc_test.c | hai 1 ano | |
quic_cfq_test.c | hai 1 ano | |
quic_client_test.c | hai 1 ano | |
quic_fc_test.c | hai 1 ano | |
quic_fifd_test.c | hai 1 ano | |
quic_multistream_test.c | hai 1 ano | |
quic_newcid_test.c | hai 1 ano | |
quic_record_test.c | hai 1 ano | |
quic_record_test_util.h | hai 1 ano | |
quic_srtm_test.c | hai 11 meses | |
quic_stream_test.c | hai 1 ano | |
quic_tserver_test.c | hai 1 ano | |
quic_txp_test.c | hai 1 ano | |
quic_txpim_test.c | %!s(int64=2) %!d(string=hai) anos | |
quic_wire_test.c | hai 1 ano | |
quicapitest.c | hai 1 ano | |
quicfaultstest.c | hai 1 ano | |
rand_status_test.c | %!s(int64=4) %!d(string=hai) anos | |
rand_test.c | hai 1 ano | |
rc2test.c | %!s(int64=4) %!d(string=hai) anos | |
rc4test.c | %!s(int64=4) %!d(string=hai) anos | |
rc5test.c | %!s(int64=4) %!d(string=hai) anos | |
rdcpu_sanitytest.c | %!s(int64=2) %!d(string=hai) anos | |
recordlentest.c | hai 1 ano | |
rpktest.c | hai 1 ano | |
rsa_complex.c | %!s(int64=2) %!d(string=hai) anos | |
rsa_mp_test.c | hai 1 ano | |
rsa_sp800_56b_test.c | hai 1 ano | |
rsa_test.c | hai 1 ano | |
rsa_x931_test.c | hai 1 ano | |
run_tests.pl | %!s(int64=2) %!d(string=hai) anos | |
safe_math_test.c | %!s(int64=2) %!d(string=hai) anos | |
sanitytest.c | hai 1 ano | |
secmemtest.c | %!s(int64=2) %!d(string=hai) anos | |
serverinfo.pem | %!s(int64=11) %!d(string=hai) anos | |
serverinfo2.pem | %!s(int64=7) %!d(string=hai) anos | |
servername_test.c | %!s(int64=3) %!d(string=hai) anos | |
session.pem | %!s(int64=6) %!d(string=hai) anos | |
sha_test.c | %!s(int64=3) %!d(string=hai) anos | |
shibboleth.pfx | %!s(int64=8) %!d(string=hai) anos | |
shlibloadtest.c | %!s(int64=3) %!d(string=hai) anos | |
simpledynamic.c | %!s(int64=3) %!d(string=hai) anos | |
simpledynamic.h | %!s(int64=3) %!d(string=hai) anos | |
siphash_internal_test.c | %!s(int64=2) %!d(string=hai) anos | |
sm2_internal_test.c | %!s(int64=3) %!d(string=hai) anos | |
sm3_internal_test.c | %!s(int64=2) %!d(string=hai) anos | |
sm4_internal_test.c | %!s(int64=3) %!d(string=hai) anos | |
smcont.bin | %!s(int64=3) %!d(string=hai) anos | |
smcont.txt | %!s(int64=8) %!d(string=hai) anos | |
smcont_zero.txt | %!s(int64=4) %!d(string=hai) anos | |
sparse_array_test.c | %!s(int64=3) %!d(string=hai) anos | |
srptest.c | %!s(int64=3) %!d(string=hai) anos | |
ssl_cert_table_internal_test.c | %!s(int64=2) %!d(string=hai) anos | |
ssl_ctx_test.c | hai 1 ano | |
ssl_handshake_rtt_test.c | hai 1 ano | |
ssl_old_test.c | hai 1 ano | |
ssl_test.c | hai 1 ano | |
ssl_test.tmpl | %!s(int64=8) %!d(string=hai) anos | |
ssl_test_ctx_test.c | %!s(int64=4) %!d(string=hai) anos | |
ssl_test_ctx_test.cnf | %!s(int64=4) %!d(string=hai) anos | |
sslapitest.c | hai 1 ano | |
sslbuffertest.c | hai 1 ano | |
sslcorrupttest.c | %!s(int64=2) %!d(string=hai) anos | |
stack_test.c | %!s(int64=3) %!d(string=hai) anos | |
sysdefault.cnf | %!s(int64=3) %!d(string=hai) anos | |
sysdefaulttest.c | %!s(int64=6) %!d(string=hai) anos | |
test.cnf | %!s(int64=3) %!d(string=hai) anos | |
test_test.c | %!s(int64=2) %!d(string=hai) anos | |
testcrl.pem | %!s(int64=26) %!d(string=hai) anos | |
testdsa.pem | %!s(int64=9) %!d(string=hai) anos | |
testdsapub.pem | %!s(int64=9) %!d(string=hai) anos | |
testec-p112r1.pem | %!s(int64=2) %!d(string=hai) anos | |
testec-p256.pem | %!s(int64=9) %!d(string=hai) anos | |
testecpub-p256.pem | %!s(int64=9) %!d(string=hai) anos | |
tested25519.pem | %!s(int64=4) %!d(string=hai) anos | |
tested25519pub.pem | %!s(int64=4) %!d(string=hai) anos | |
tested448.pem | %!s(int64=4) %!d(string=hai) anos | |
tested448pub.pem | %!s(int64=4) %!d(string=hai) anos | |
testp7.pem | %!s(int64=24) %!d(string=hai) anos | |
testreq2.pem | %!s(int64=26) %!d(string=hai) anos | |
testrsa.pem | %!s(int64=4) %!d(string=hai) anos | |
testrsa2048.pem | %!s(int64=4) %!d(string=hai) anos | |
testrsa2048pub.pem | %!s(int64=2) %!d(string=hai) anos | |
testrsa_withattrs.der | %!s(int64=3) %!d(string=hai) anos | |
testrsa_withattrs.pem | %!s(int64=3) %!d(string=hai) anos | |
testrsapss.pem | %!s(int64=3) %!d(string=hai) anos | |
testrsapssmandatory.pem | %!s(int64=3) %!d(string=hai) anos | |
testrsapub.pem | %!s(int64=9) %!d(string=hai) anos | |
testsid.pem | %!s(int64=3) %!d(string=hai) anos | |
testutil.h | hai 1 ano | |
testx509.pem | %!s(int64=4) %!d(string=hai) anos | |
threadpool_test.c | hai 1 ano | |
threadstest.c | hai 1 ano | |
threadstest.h | %!s(int64=3) %!d(string=hai) anos | |
threadstest_fips.c | %!s(int64=3) %!d(string=hai) anos | |
time_offset_test.c | %!s(int64=6) %!d(string=hai) anos | |
time_test.c | hai 1 ano | |
timing_load_creds.c | hai 1 ano | |
tls-provider.c | hai 1 ano | |
tls13ccstest.c | hai 1 ano | |
tls13encryptiontest.c | hai 1 ano | |
tls13secretstest.c | hai 1 ano | |
trace_api_test.c | hai 1 ano | |
uitest.c | %!s(int64=2) %!d(string=hai) anos | |
upcallstest.c | hai 1 ano | |
user_property_test.c | hai 1 ano | |
v3-cert1.pem | %!s(int64=26) %!d(string=hai) anos | |
v3-cert2.pem | %!s(int64=26) %!d(string=hai) anos | |
v3_ca_exts.cnf | %!s(int64=3) %!d(string=hai) anos | |
v3ext.c | %!s(int64=2) %!d(string=hai) anos | |
v3nametest.c | hai 1 ano | |
verify_extra_test.c | %!s(int64=2) %!d(string=hai) anos | |
versions.c | %!s(int64=6) %!d(string=hai) anos | |
wpackettest.c | hai 1 ano | |
x509_check_cert_pkey_test.c | hai 1 ano | |
x509_dup_cert_test.c | %!s(int64=3) %!d(string=hai) anos | |
x509_internal_test.c | %!s(int64=3) %!d(string=hai) anos | |
x509_test.c | %!s(int64=2) %!d(string=hai) anos | |
x509_time_test.c | %!s(int64=2) %!d(string=hai) anos | |
x509aux.c | hai 1 ano |
For any test that you want to perform, you write a script located in
test/recipes/
, named {nn}-test_{name}.t
,
where {nn}
is a two digit number and
{name}
is a unique name of your choice.
Please note that if a test involves a new testing executable, you will need to do some additions in test/build.info. Please refer to the section "Changes to test/build.info" below.
A test executable is named test/{name}test.c
A test recipe is named test/recipes/{nn}-test_{name}.t
, where {nn}
is a two
digit number and {name}
is a unique name of your choice.
The number {nn}
is (somewhat loosely) grouped as follows:
00-04 sanity, internal and essential API tests
05-09 individual symmetric cipher algorithms
10-14 math (bignum)
15-19 individual asymmetric cipher algorithms
20-24 openssl commands (some otherwise not tested)
25-29 certificate forms, generation and verification
30-35 engine and evp
60-79 APIs:
60 X509 subsystem
61 BIO subsystem
65 CMP subsystem
70 PACKET layer
80-89 "larger" protocols (CA, CMS, OCSP, SSL, TSA)
90-98 misc
99 most time consuming tests [such as test_fuzz]
A script that just runs a program looks like this:
#! /usr/bin/env perl
use OpenSSL::Test::Simple;
simple_test("test_{name}", "{name}test", "{name}");
{name}
is the unique name you have chosen for your test.
The second argument to simple_test
is the test executable, and simple_test
expects it to be located in test/
For documentation on OpenSSL::Test::Simple
,
do perldoc util/perl/OpenSSL/Test/Simple.pm
.
For more complex tests, you will need to read up on Test::More and
OpenSSL::Test. Test::More is normally preinstalled, do man Test::More
for
documentation. For OpenSSL::Test, do perldoc util/perl/OpenSSL/Test.pm
.
A script to start from could be this:
#! /usr/bin/env perl
use strict;
use warnings;
use OpenSSL::Test;
setup("test_{name}");
plan tests => 2; # The number of tests being performed
ok(test1, "test1");
ok(test2, "test1");
sub test1
{
# test feature 1
}
sub test2
{
# test feature 2
}
Whenever a new test involves a new test executable you need to do the following (at all times, replace {NAME} and {name} with the name of your test):
add {name}
to the list of programs under PROGRAMS_NO_INST
create a three line description of how to build the test, you will have to modify the include paths and source files if you don't want to use the basic test framework:
SOURCE[{name}]={name}.c INCLUDE[{name}]=.. ../include ../apps/include DEPEND[{name}]=../libcrypto libtestutil.a
#include "testutil.h"
static int my_test(void)
{
int testresult = 0; /* Assume the test will fail */
int observed;
observed = function(); /* Call the code under test */
if (!TEST_int_eq(observed, 2)) /* Check the result is correct */
goto end; /* Exit on failure - optional */
testresult = 1; /* Mark the test case a success */
end:
cleanup(); /* Any cleanup you require */
return testresult;
}
int setup_tests(void)
{
ADD_TEST(my_test); /* Add each test separately */
return 1; /* Indicates success. Return 0 */
/* to produce an error with a */
/* usage message and -1 for */
/* failure to set up with no */
/* usage message. */
}
You should use the TEST_xxx
macros provided by testutil.h
to test all failure
conditions. These macros produce an error message in a standard format if the
condition is not met (and nothing if the condition is met). Additional
information can be presented with the TEST_info
macro that takes a printf
format string and arguments. TEST_error
is useful for complicated conditions,
it also takes a printf
format string and argument. In all cases the TEST_xxx
macros are guaranteed to evaluate their arguments exactly once. This means
that expressions with side effects are allowed as parameters. Thus,
if (!TEST_ptr(ptr = OPENSSL_malloc(..)))
works fine and can be used in place of:
ptr = OPENSSL_malloc(..);
if (!TEST_ptr(ptr))
The former produces a more meaningful message on failure than the latter.
Note that the test infrastructure automatically sets up all required environment
variables (such as OPENSSL_MODULES
, OPENSSL_CONF
, etc.) for the tests.
Individual tests may choose to override the default settings as required.