Tomas Mraz ea82158103 ed25519 and ed448: fix incorrect OSSL_PKEY_PARAM_MAX_SIZE | 3 jaren geleden | |
---|---|---|
.. | ||
certs | 3 jaren geleden | |
ct | 4 jaren geleden | |
d2i-tests | 8 jaren geleden | |
helpers | 3 jaren geleden | |
ocsp-tests | 7 jaren geleden | |
recipes | 3 jaren geleden | |
smime-certs | 3 jaren geleden | |
ssl-tests | 3 jaren geleden | |
testutil | 3 jaren geleden | |
CAtsa.cnf | 3 jaren geleden | |
README-dev.md | 4 jaren geleden | |
README-external.md | 3 jaren geleden | |
README.md | 3 jaren geleden | |
README.ssltest.md | 4 jaren geleden | |
aborttest.c | 6 jaren geleden | |
acvp_test.c | 3 jaren geleden | |
acvp_test.inc | 3 jaren geleden | |
aesgcmtest.c | 3 jaren geleden | |
afalgtest.c | 4 jaren geleden | |
algorithmid_test.c | 3 jaren geleden | |
asn1_decode_test.c | 3 jaren geleden | |
asn1_dsa_internal_test.c | 4 jaren geleden | |
asn1_encode_test.c | 3 jaren geleden | |
asn1_internal_test.c | 3 jaren geleden | |
asn1_string_table_test.c | 6 jaren geleden | |
asn1_time_test.c | 4 jaren geleden | |
asynciotest.c | 4 jaren geleden | |
asynctest.c | 4 jaren geleden | |
bad_dtls_test.c | 3 jaren geleden | |
bftest.c | 4 jaren geleden | |
bio_callback_test.c | 3 jaren geleden | |
bio_core_test.c | 3 jaren geleden | |
bio_enc_test.c | 6 jaren geleden | |
bio_memleak_test.c | 4 jaren geleden | |
bio_prefix_text.c | 4 jaren geleden | |
bio_readbuffer_test.c | 3 jaren geleden | |
bioprinttest.c | 4 jaren geleden | |
bn_internal_test.c | 3 jaren geleden | |
bn_rand_range.h | 5 jaren geleden | |
bntest.c | 3 jaren geleden | |
bntests.pl | 6 jaren geleden | |
build.info | 3 jaren geleden | |
ca-and-certs.cnf | 3 jaren geleden | |
casttest.c | 4 jaren geleden | |
chacha_internal_test.c | 5 jaren geleden | |
cipher_overhead_test.c | 3 jaren geleden | |
cipherbytes_test.c | 4 jaren geleden | |
cipherlist_test.c | 3 jaren geleden | |
ciphername_test.c | 4 jaren geleden | |
clienthellotest.c | 3 jaren geleden | |
cmactest.c | 4 jaren geleden | |
cmp_asn_test.c | 3 jaren geleden | |
cmp_client_test.c | 3 jaren geleden | |
cmp_ctx_test.c | 3 jaren geleden | |
cmp_hdr_test.c | 3 jaren geleden | |
cmp_msg_test.c | 3 jaren geleden | |
cmp_protect_test.c | 3 jaren geleden | |
cmp_server_test.c | 3 jaren geleden | |
cmp_status_test.c | 4 jaren geleden | |
cmp_vfy_test.c | 3 jaren geleden | |
cms-examples.pl | 6 jaren geleden | |
cmsapitest.c | 3 jaren geleden | |
conf_include_test.c | 3 jaren geleden | |
confdump.c | 3 jaren geleden | |
constant_time_test.c | 5 jaren geleden | |
context_internal_test.c | 3 jaren geleden | |
crltest.c | 4 jaren geleden | |
ct_test.c | 4 jaren geleden | |
ctype_internal_test.c | 5 jaren geleden | |
curve448_internal_test.c | 3 jaren geleden | |
d2i_test.c | 4 jaren geleden | |
danetest.c | 3 jaren geleden | |
danetest.in | 6 jaren geleden | |
danetest.pem | 8 jaren geleden | |
data.bin | 4 jaren geleden | |
data2.bin | 3 jaren geleden | |
default-and-fips.cnf | 4 jaren geleden | |
default-and-legacy.cnf | 5 jaren geleden | |
default.cnf | 5 jaren geleden | |
defltfips_test.c | 3 jaren geleden | |
destest.c | 4 jaren geleden | |
dhtest.c | 3 jaren geleden | |
drbgtest.c | 3 jaren geleden | |
dsa_no_digest_size_test.c | 4 jaren geleden | |
dsatest.c | 3 jaren geleden | |
dtls_mtu_test.c | 4 jaren geleden | |
dtlstest.c | 3 jaren geleden | |
dtlsv1listentest.c | 6 jaren geleden | |
ec_internal_test.c | 3 jaren geleden | |
ecdsatest.c | 3 jaren geleden | |
ecdsatest.h | 5 jaren geleden | |
ecstresstest.c | 3 jaren geleden | |
ectest.c | 3 jaren geleden | |
endecode_test.c | 3 jaren geleden | |
endecoder_legacy_test.c | 3 jaren geleden | |
enginetest.c | 3 jaren geleden | |
errtest.c | 3 jaren geleden | |
evp_extra_test.c | 3 jaren geleden | |
evp_extra_test2.c | 3 jaren geleden | |
evp_fetch_prov_test.c | 3 jaren geleden | |
evp_kdf_test.c | 3 jaren geleden | |
evp_libctx_test.c | 3 jaren geleden | |
evp_pkey_dparams_test.c | 3 jaren geleden | |
evp_pkey_provided_test.c | 3 jaren geleden | |
evp_test.c | 3 jaren geleden | |
exdatatest.c | 3 jaren geleden | |
exptest.c | 3 jaren geleden | |
fatalerrtest.c | 4 jaren geleden | |
ffc_internal_test.c | 3 jaren geleden | |
filterprov.c | 3 jaren geleden | |
filterprov.h | 3 jaren geleden | |
fips-and-base.cnf | 4 jaren geleden | |
fips.cnf | 4 jaren geleden | |
generate_buildtest.pl | 6 jaren geleden | |
generate_ssl_tests.pl | 4 jaren geleden | |
gmdifftest.c | 3 jaren geleden | |
gosttest.c | 4 jaren geleden | |
hexstr_test.c | 3 jaren geleden | |
hmactest.c | 3 jaren geleden | |
http_test.c | 3 jaren geleden | |
ideatest.c | 4 jaren geleden | |
igetest.c | 5 jaren geleden | |
insta.priv.pem | 4 jaren geleden | |
insta_ca.cert.pem | 4 jaren geleden | |
keymgmt_internal_test.c | 3 jaren geleden | |
legacy.cnf | 5 jaren geleden | |
lhash_test.c | 4 jaren geleden | |
mdc2_internal_test.c | 4 jaren geleden | |
mdc2test.c | 4 jaren geleden | |
memleaktest.c | 3 jaren geleden | |
modes_internal_test.c | 3 jaren geleden | |
moduleloadtest.c | 3 jaren geleden | |
namemap_internal_test.c | 3 jaren geleden | |
ocspapitest.c | 4 jaren geleden | |
ossl_store_test.c | 3 jaren geleden | |
p_test.c | 3 jaren geleden | |
packettest.c | 5 jaren geleden | |
param_build_test.c | 3 jaren geleden | |
params_api_test.c | 3 jaren geleden | |
params_conversion_test.c | 3 jaren geleden | |
params_test.c | 3 jaren geleden | |
pbelutest.c | 6 jaren geleden | |
pbetest.c | 3 jaren geleden | |
pem_read_depr_test.c | 4 jaren geleden | |
pemtest.c | 6 jaren geleden | |
pkcs12_format_test.c | 3 jaren geleden | |
pkcs7-1.pem | 26 jaren geleden | |
pkcs7.pem | 26 jaren geleden | |
pkcs7_test.c | 3 jaren geleden | |
pkey_meth_kdf_test.c | 4 jaren geleden | |
pkey_meth_test.c | 4 jaren geleden | |
pkits-test.pl | 6 jaren geleden | |
poly1305_internal_test.c | 5 jaren geleden | |
property_test.c | 3 jaren geleden | |
provider_fallback_test.c | 3 jaren geleden | |
provider_internal_test.c | 3 jaren geleden | |
provider_internal_test.cnf.in | 4 jaren geleden | |
provider_status_test.c | 4 jaren geleden | |
provider_test.c | 3 jaren geleden | |
proxy.cnf | 3 jaren geleden | |
rand_status_test.c | 4 jaren geleden | |
rc2test.c | 4 jaren geleden | |
rc4test.c | 4 jaren geleden | |
rc5test.c | 4 jaren geleden | |
rdrand_sanitytest.c | 5 jaren geleden | |
recordlentest.c | 3 jaren geleden | |
rsa_complex.c | 6 jaren geleden | |
rsa_mp_test.c | 3 jaren geleden | |
rsa_sp800_56b_test.c | 3 jaren geleden | |
rsa_test.c | 3 jaren geleden | |
run_tests.pl | 3 jaren geleden | |
sanitytest.c | 6 jaren geleden | |
secmemtest.c | 4 jaren geleden | |
serverinfo.pem | 11 jaren geleden | |
serverinfo2.pem | 7 jaren geleden | |
servername_test.c | 3 jaren geleden | |
session.pem | 6 jaren geleden | |
shibboleth.pfx | 8 jaren geleden | |
shlibloadtest.c | 3 jaren geleden | |
simpledynamic.c | 4 jaren geleden | |
simpledynamic.h | 3 jaren geleden | |
siphash_internal_test.c | 3 jaren geleden | |
sm2_internal_test.c | 3 jaren geleden | |
sm4_internal_test.c | 3 jaren geleden | |
smcont.bin | 3 jaren geleden | |
smcont.txt | 8 jaren geleden | |
smcont_zero.txt | 4 jaren geleden | |
sparse_array_test.c | 3 jaren geleden | |
srptest.c | 3 jaren geleden | |
ssl_cert_table_internal_test.c | 3 jaren geleden | |
ssl_ctx_test.c | 4 jaren geleden | |
ssl_old_test.c | 3 jaren geleden | |
ssl_test.c | 3 jaren geleden | |
ssl_test.tmpl | 8 jaren geleden | |
ssl_test_ctx_test.c | 4 jaren geleden | |
ssl_test_ctx_test.cnf | 4 jaren geleden | |
sslapitest.c | 3 jaren geleden | |
sslbuffertest.c | 4 jaren geleden | |
sslcorrupttest.c | 4 jaren geleden | |
stack_test.c | 3 jaren geleden | |
sysdefault.cnf | 6 jaren geleden | |
sysdefaulttest.c | 6 jaren geleden | |
test.cnf | 3 jaren geleden | |
test_test.c | 5 jaren geleden | |
testcrl.pem | 26 jaren geleden | |
testdsa.pem | 9 jaren geleden | |
testdsapub.pem | 9 jaren geleden | |
testec-p256.pem | 9 jaren geleden | |
testecpub-p256.pem | 9 jaren geleden | |
tested25519.pem | 5 jaren geleden | |
tested25519pub.pem | 5 jaren geleden | |
tested448.pem | 5 jaren geleden | |
tested448pub.pem | 5 jaren geleden | |
testp7.pem | 24 jaren geleden | |
testreq2.pem | 26 jaren geleden | |
testrsa.pem | 4 jaren geleden | |
testrsa2048.pem | 4 jaren geleden | |
testrsa_withattrs.der | 3 jaren geleden | |
testrsa_withattrs.pem | 3 jaren geleden | |
testrsapss.pem | 3 jaren geleden | |
testrsapssmandatory.pem | 3 jaren geleden | |
testrsapub.pem | 9 jaren geleden | |
testsid.pem | 3 jaren geleden | |
testutil.h | 3 jaren geleden | |
testx509.pem | 4 jaren geleden | |
threadstest.c | 3 jaren geleden | |
threadstest.h | 3 jaren geleden | |
threadstest_fips.c | 3 jaren geleden | |
time_offset_test.c | 6 jaren geleden | |
tls-provider.c | 3 jaren geleden | |
tls13ccstest.c | 4 jaren geleden | |
tls13encryptiontest.c | 3 jaren geleden | |
tls13secretstest.c | 3 jaren geleden | |
uitest.c | 4 jaren geleden | |
user_property_test.c | 3 jaren geleden | |
v3-cert1.pem | 26 jaren geleden | |
v3-cert2.pem | 26 jaren geleden | |
v3_ca_exts.cnf | 3 jaren geleden | |
v3ext.c | 4 jaren geleden | |
v3nametest.c | 3 jaren geleden | |
verify_extra_test.c | 3 jaren geleden | |
versions.c | 6 jaren geleden | |
wpackettest.c | 4 jaren geleden | |
x509_check_cert_pkey_test.c | 3 jaren geleden | |
x509_dup_cert_test.c | 4 jaren geleden | |
x509_internal_test.c | 5 jaren geleden | |
x509_time_test.c | 4 jaren geleden | |
x509aux.c | 3 jaren geleden |
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/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/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; /* Indicate success */
}
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.