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`). | 11 tháng trước cách đây | |
---|---|---|
.. | ||
certs | 1 năm trước cách đây | |
ct | 3 năm trước cách đây | |
d2i-tests | 8 năm trước cách đây | |
helpers | 1 năm trước cách đây | |
ocsp-tests | 7 năm trước cách đây | |
recipes | 11 tháng trước cách đây | |
smime-certs | 1 năm trước cách đây | |
smime-eml | 1 năm trước cách đây | |
ssl-tests | 1 năm trước cách đây | |
testutil | 1 năm trước cách đây | |
CAtsa.cnf | 1 năm trước cách đây | |
README-dev.md | 1 năm trước cách đây | |
README-external.md | 1 năm trước cách đây | |
README.md | 1 năm trước cách đây | |
README.ssltest.md | 2 năm trước cách đây | |
aborttest.c | 6 năm trước cách đây | |
acvp_test.c | 2 năm trước cách đây | |
acvp_test.inc | 3 năm trước cách đây | |
aesgcmtest.c | 2 năm trước cách đây | |
afalgtest.c | 1 năm trước cách đây | |
algorithmid_test.c | 3 năm trước cách đây | |
asn1_decode_test.c | 3 năm trước cách đây | |
asn1_dsa_internal_test.c | 4 năm trước cách đây | |
asn1_encode_test.c | 3 năm trước cách đây | |
asn1_internal_test.c | 1 năm trước cách đây | |
asn1_string_table_test.c | 6 năm trước cách đây | |
asn1_time_test.c | 2 năm trước cách đây | |
asynciotest.c | 4 năm trước cách đây | |
asynctest.c | 2 năm trước cách đây | |
bad_dtls_test.c | 2 năm trước cách đây | |
bftest.c | 3 năm trước cách đây | |
bio_addr_test.c | 1 năm trước cách đây | |
bio_callback_test.c | 3 năm trước cách đây | |
bio_comp_test.c | 2 năm trước cách đây | |
bio_core_test.c | 1 năm trước cách đây | |
bio_dgram_test.c | 1 năm trước cách đây | |
bio_enc_test.c | 2 năm trước cách đây | |
bio_memleak_test.c | 1 năm trước cách đây | |
bio_prefix_text.c | 3 năm trước cách đây | |
bio_readbuffer_test.c | 3 năm trước cách đây | |
bio_tfo_test.c | 2 năm trước cách đây | |
bioprinttest.c | 4 năm trước cách đây | |
bn_internal_test.c | 3 năm trước cách đây | |
bn_rand_range.h | 5 năm trước cách đây | |
bntest.c | 1 năm trước cách đây | |
bntests.pl | 6 năm trước cách đây | |
build.info | 11 tháng trước cách đây | |
build_wincrypt_test.c | 1 năm trước cách đây | |
ca-and-certs.cnf | 1 năm trước cách đây | |
ca_internals_test.c | 2 năm trước cách đây | |
casttest.c | 4 năm trước cách đây | |
cc_dummy.c | 1 năm trước cách đây | |
cert_comp_test.c | 2 năm trước cách đây | |
chacha_internal_test.c | 1 năm trước cách đây | |
cipher_overhead_test.c | 3 năm trước cách đây | |
cipherbytes_test.c | 4 năm trước cách đây | |
cipherlist_test.c | 3 năm trước cách đây | |
ciphername_test.c | 4 năm trước cách đây | |
clienthellotest.c | 3 năm trước cách đây | |
cmactest.c | 1 năm trước cách đây | |
cmp_asn_test.c | 1 năm trước cách đây | |
cmp_client_test.c | 1 năm trước cách đây | |
cmp_ctx_test.c | 1 năm trước cách đây | |
cmp_hdr_test.c | 1 năm trước cách đây | |
cmp_msg_test.c | 1 năm trước cách đây | |
cmp_protect_test.c | 1 năm trước cách đây | |
cmp_server_test.c | 3 năm trước cách đây | |
cmp_status_test.c | 1 năm trước cách đây | |
cmp_vfy_test.c | 1 năm trước cách đây | |
cms-examples.pl | 6 năm trước cách đây | |
cmsapitest.c | 1 năm trước cách đây | |
conf_include_test.c | 1 năm trước cách đây | |
confdump.c | 3 năm trước cách đây | |
constant_time_test.c | 3 năm trước cách đây | |
context_internal_test.c | 2 năm trước cách đây | |
crltest.c | 2 năm trước cách đây | |
ct_test.c | 2 năm trước cách đây | |
ctype_internal_test.c | 5 năm trước cách đây | |
curve448_internal_test.c | 1 năm trước cách đây | |
d2i_test.c | 4 năm trước cách đây | |
dane-cross.in | 2 năm trước cách đây | |
danetest.c | 2 năm trước cách đây | |
danetest.in | 6 năm trước cách đây | |
danetest.pem | 8 năm trước cách đây | |
data.bin | 4 năm trước cách đây | |
data2.bin | 3 năm trước cách đây | |
decoder_propq_test.c | 1 năm trước cách đây | |
default-and-fips.cnf | 3 năm trước cách đây | |
default-and-legacy.cnf | 3 năm trước cách đây | |
default.cnf | 3 năm trước cách đây | |
defltfips_test.c | 2 năm trước cách đây | |
destest.c | 1 năm trước cách đây | |
dhkem_test.inc | 1 năm trước cách đây | |
dhtest.c | 1 năm trước cách đây | |
drbgtest.c | 1 năm trước cách đây | |
dsa_no_digest_size_test.c | 4 năm trước cách đây | |
dsatest.c | 1 năm trước cách đây | |
dtls_mtu_test.c | 2 năm trước cách đây | |
dtlstest.c | 1 năm trước cách đây | |
dtlsv1listentest.c | 6 năm trước cách đây | |
ec_internal_test.c | 2 năm trước cách đây | |
ecdsatest.c | 1 năm trước cách đây | |
ecdsatest.h | 5 năm trước cách đây | |
ecstresstest.c | 3 năm trước cách đây | |
ectest.c | 1 năm trước cách đây | |
endecode_test.c | 1 năm trước cách đây | |
endecoder_legacy_test.c | 3 năm trước cách đây | |
enginetest.c | 2 năm trước cách đây | |
errtest.c | 1 năm trước cách đây | |
event_queue_test.c | 2 năm trước cách đây | |
evp_extra_test.c | 1 năm trước cách đây | |
evp_extra_test2.c | 1 năm trước cách đây | |
evp_fetch_prov_test.c | 2 năm trước cách đây | |
evp_kdf_test.c | 1 năm trước cách đây | |
evp_libctx_test.c | 2 năm trước cách đây | |
evp_pkey_ctx_new_from_name.c | 2 năm trước cách đây | |
evp_pkey_dhkem_test.c | 1 năm trước cách đây | |
evp_pkey_dparams_test.c | 2 năm trước cách đây | |
evp_pkey_provided_test.c | 1 năm trước cách đây | |
evp_test.c | 1 năm trước cách đây | |
evp_xof_test.c | 1 năm trước cách đây | |
exdatatest.c | 3 năm trước cách đây | |
exptest.c | 1 năm trước cách đây | |
ext_internal_test.c | 1 năm trước cách đây | |
fake_rsaprov.c | 1 năm trước cách đây | |
fake_rsaprov.h | 1 năm trước cách đây | |
fatalerrtest.c | 4 năm trước cách đây | |
ffc_internal_test.c | 1 năm trước cách đây | |
filterprov.c | 1 năm trước cách đây | |
filterprov.h | 3 năm trước cách đây | |
fips-alt.cnf | 3 năm trước cách đây | |
fips-and-base.cnf | 1 năm trước cách đây | |
fips.cnf | 3 năm trước cách đây | |
fips_version_test.c | 2 năm trước cách đây | |
generate_buildtest.pl | 6 năm trước cách đây | |
generate_ssl_tests.pl | 3 năm trước cách đây | |
gmdifftest.c | 3 năm trước cách đây | |
hexstr_test.c | 3 năm trước cách đây | |
hmactest.c | 2 năm trước cách đây | |
hpke_test.c | 1 năm trước cách đây | |
http_test.c | 2 năm trước cách đây | |
ideatest.c | 4 năm trước cách đây | |
igetest.c | 5 năm trước cách đây | |
insta.priv.pem | 3 năm trước cách đây | |
insta_ca.cert.pem | 3 năm trước cách đây | |
keymgmt_internal_test.c | 1 năm trước cách đây | |
legacy.cnf | 3 năm trước cách đây | |
lhash_test.c | 2 năm trước cách đây | |
list_test.c | 2 năm trước cách đây | |
localetest.c | 2 năm trước cách đây | |
mdc2_internal_test.c | 4 năm trước cách đây | |
mdc2test.c | 1 năm trước cách đây | |
membio_test.c | 1 năm trước cách đây | |
memleaktest.c | 3 năm trước cách đây | |
modes_internal_test.c | 3 năm trước cách đây | |
moduleloadtest.c | 3 năm trước cách đây | |
namemap_internal_test.c | 3 năm trước cách đây | |
nodefltctxtest.c | 1 năm trước cách đây | |
null.cnf | 1 năm trước cách đây | |
ocspapitest.c | 1 năm trước cách đây | |
ossl_store_test.c | 3 năm trước cách đây | |
p_test.c | 1 năm trước cách đây | |
packettest.c | 1 năm trước cách đây | |
pairwise_fail_test.c | 1 năm trước cách đây | |
param_build_test.c | 1 năm trước cách đây | |
params_api_test.c | 2 năm trước cách đây | |
params_conversion_test.c | 2 năm trước cách đây | |
params_test.c | 2 năm trước cách đây | |
pbelutest.c | 6 năm trước cách đây | |
pbetest.c | 1 năm trước cách đây | |
pem_read_depr_test.c | 3 năm trước cách đây | |
pemtest.c | 1 năm trước cách đây | |
pkcs12_api_test.c | 1 năm trước cách đây | |
pkcs12_format_test.c | 1 năm trước cách đây | |
pkcs7-1.pem | 26 năm trước cách đây | |
pkcs7.pem | 26 năm trước cách đây | |
pkcs7_test.c | 3 năm trước cách đây | |
pkey_meth_kdf_test.c | 4 năm trước cách đây | |
pkey_meth_test.c | 4 năm trước cách đây | |
pkits-test.pl | 6 năm trước cách đây | |
poly1305_internal_test.c | 5 năm trước cách đây | |
priority_queue_test.c | 1 năm trước cách đây | |
property_test.c | 1 năm trước cách đây | |
prov_config_test.c | 3 năm trước cách đây | |
provfetchtest.c | 1 năm trước cách đây | |
provider_default_search_path_test.c | 1 năm trước cách đây | |
provider_fallback_test.c | 3 năm trước cách đây | |
provider_internal_test.c | 1 năm trước cách đây | |
provider_internal_test.cnf.in | 3 năm trước cách đây | |
provider_pkey_test.c | 1 năm trước cách đây | |
provider_status_test.c | 3 năm trước cách đây | |
provider_test.c | 1 năm trước cách đây | |
proxy.cnf | 3 năm trước cách đây | |
punycode_test.c | 1 năm trước cách đây | |
quic_ackm_test.c | 1 năm trước cách đây | |
quic_cc_test.c | 1 năm trước cách đây | |
quic_cfq_test.c | 1 năm trước cách đây | |
quic_client_test.c | 1 năm trước cách đây | |
quic_fc_test.c | 1 năm trước cách đây | |
quic_fifd_test.c | 1 năm trước cách đây | |
quic_multistream_test.c | 1 năm trước cách đây | |
quic_newcid_test.c | 1 năm trước cách đây | |
quic_record_test.c | 1 năm trước cách đây | |
quic_record_test_util.h | 1 năm trước cách đây | |
quic_srtm_test.c | 11 tháng trước cách đây | |
quic_stream_test.c | 1 năm trước cách đây | |
quic_tserver_test.c | 1 năm trước cách đây | |
quic_txp_test.c | 1 năm trước cách đây | |
quic_txpim_test.c | 2 năm trước cách đây | |
quic_wire_test.c | 1 năm trước cách đây | |
quicapitest.c | 1 năm trước cách đây | |
quicfaultstest.c | 1 năm trước cách đây | |
rand_status_test.c | 4 năm trước cách đây | |
rand_test.c | 1 năm trước cách đây | |
rc2test.c | 4 năm trước cách đây | |
rc4test.c | 4 năm trước cách đây | |
rc5test.c | 4 năm trước cách đây | |
rdcpu_sanitytest.c | 2 năm trước cách đây | |
recordlentest.c | 1 năm trước cách đây | |
rpktest.c | 1 năm trước cách đây | |
rsa_complex.c | 2 năm trước cách đây | |
rsa_mp_test.c | 1 năm trước cách đây | |
rsa_sp800_56b_test.c | 1 năm trước cách đây | |
rsa_test.c | 1 năm trước cách đây | |
rsa_x931_test.c | 1 năm trước cách đây | |
run_tests.pl | 2 năm trước cách đây | |
safe_math_test.c | 2 năm trước cách đây | |
sanitytest.c | 1 năm trước cách đây | |
secmemtest.c | 2 năm trước cách đây | |
serverinfo.pem | 11 năm trước cách đây | |
serverinfo2.pem | 7 năm trước cách đây | |
servername_test.c | 3 năm trước cách đây | |
session.pem | 6 năm trước cách đây | |
sha_test.c | 3 năm trước cách đây | |
shibboleth.pfx | 8 năm trước cách đây | |
shlibloadtest.c | 3 năm trước cách đây | |
simpledynamic.c | 3 năm trước cách đây | |
simpledynamic.h | 3 năm trước cách đây | |
siphash_internal_test.c | 2 năm trước cách đây | |
sm2_internal_test.c | 3 năm trước cách đây | |
sm3_internal_test.c | 2 năm trước cách đây | |
sm4_internal_test.c | 3 năm trước cách đây | |
smcont.bin | 3 năm trước cách đây | |
smcont.txt | 8 năm trước cách đây | |
smcont_zero.txt | 4 năm trước cách đây | |
sparse_array_test.c | 3 năm trước cách đây | |
srptest.c | 3 năm trước cách đây | |
ssl_cert_table_internal_test.c | 2 năm trước cách đây | |
ssl_ctx_test.c | 1 năm trước cách đây | |
ssl_handshake_rtt_test.c | 1 năm trước cách đây | |
ssl_old_test.c | 1 năm trước cách đây | |
ssl_test.c | 1 năm trước cách đây | |
ssl_test.tmpl | 8 năm trước cách đây | |
ssl_test_ctx_test.c | 4 năm trước cách đây | |
ssl_test_ctx_test.cnf | 4 năm trước cách đây | |
sslapitest.c | 1 năm trước cách đây | |
sslbuffertest.c | 1 năm trước cách đây | |
sslcorrupttest.c | 2 năm trước cách đây | |
stack_test.c | 3 năm trước cách đây | |
sysdefault.cnf | 3 năm trước cách đây | |
sysdefaulttest.c | 6 năm trước cách đây | |
test.cnf | 3 năm trước cách đây | |
test_test.c | 2 năm trước cách đây | |
testcrl.pem | 26 năm trước cách đây | |
testdsa.pem | 9 năm trước cách đây | |
testdsapub.pem | 9 năm trước cách đây | |
testec-p112r1.pem | 2 năm trước cách đây | |
testec-p256.pem | 9 năm trước cách đây | |
testecpub-p256.pem | 9 năm trước cách đây | |
tested25519.pem | 4 năm trước cách đây | |
tested25519pub.pem | 4 năm trước cách đây | |
tested448.pem | 4 năm trước cách đây | |
tested448pub.pem | 4 năm trước cách đây | |
testp7.pem | 24 năm trước cách đây | |
testreq2.pem | 26 năm trước cách đây | |
testrsa.pem | 4 năm trước cách đây | |
testrsa2048.pem | 4 năm trước cách đây | |
testrsa2048pub.pem | 2 năm trước cách đây | |
testrsa_withattrs.der | 3 năm trước cách đây | |
testrsa_withattrs.pem | 3 năm trước cách đây | |
testrsapss.pem | 3 năm trước cách đây | |
testrsapssmandatory.pem | 3 năm trước cách đây | |
testrsapub.pem | 9 năm trước cách đây | |
testsid.pem | 3 năm trước cách đây | |
testutil.h | 1 năm trước cách đây | |
testx509.pem | 4 năm trước cách đây | |
threadpool_test.c | 1 năm trước cách đây | |
threadstest.c | 1 năm trước cách đây | |
threadstest.h | 3 năm trước cách đây | |
threadstest_fips.c | 3 năm trước cách đây | |
time_offset_test.c | 6 năm trước cách đây | |
time_test.c | 1 năm trước cách đây | |
timing_load_creds.c | 1 năm trước cách đây | |
tls-provider.c | 1 năm trước cách đây | |
tls13ccstest.c | 1 năm trước cách đây | |
tls13encryptiontest.c | 1 năm trước cách đây | |
tls13secretstest.c | 1 năm trước cách đây | |
trace_api_test.c | 1 năm trước cách đây | |
uitest.c | 2 năm trước cách đây | |
upcallstest.c | 1 năm trước cách đây | |
user_property_test.c | 1 năm trước cách đây | |
v3-cert1.pem | 26 năm trước cách đây | |
v3-cert2.pem | 26 năm trước cách đây | |
v3_ca_exts.cnf | 3 năm trước cách đây | |
v3ext.c | 2 năm trước cách đây | |
v3nametest.c | 1 năm trước cách đây | |
verify_extra_test.c | 2 năm trước cách đây | |
versions.c | 6 năm trước cách đây | |
wpackettest.c | 1 năm trước cách đây | |
x509_check_cert_pkey_test.c | 1 năm trước cách đây | |
x509_dup_cert_test.c | 3 năm trước cách đây | |
x509_internal_test.c | 3 năm trước cách đây | |
x509_test.c | 2 năm trước cách đây | |
x509_time_test.c | 2 năm trước cách đây | |
x509aux.c | 1 năm trước cách đây |
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.