diff options
author | Rich Salz <rsalz@openssl.org> | 2017-04-12 09:27:33 -0400 |
---|---|---|
committer | Rich Salz <rsalz@openssl.org> | 2017-04-12 11:20:48 -0400 |
commit | f1e793cc974094da7da52c6958ad7b972b4a446d (patch) | |
tree | 90abed20172c2f707f211c77f2b5fa7e45e90c47 /test/x509aux.c | |
parent | e2a29ad6c5f6b42ce71400595cb504cbf8f3646a (diff) | |
download | openssl-new-f1e793cc974094da7da52c6958ad7b972b4a446d.tar.gz |
Address review feedback (to be squashed)
Reviewed-by: Richard Levitte <levitte@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/3189)
Diffstat (limited to 'test/x509aux.c')
-rw-r--r-- | test/x509aux.c | 37 |
1 files changed, 16 insertions, 21 deletions
diff --git a/test/x509aux.c b/test/x509aux.c index 2ad7b6d1cd..7030a13365 100644 --- a/test/x509aux.c +++ b/test/x509aux.c @@ -21,7 +21,11 @@ #include "test_main_custom.h" #include "testutil.h" -static int test_certs(BIO *fp) + +/* List of files, from argv */ +static char **files; + +static int test_certs(int num) { int count; char *name = 0; @@ -31,6 +35,10 @@ static int test_certs(BIO *fp) typedef X509 *(*d2i_X509_t)(X509 **, const unsigned char **, long); typedef int (*i2d_X509_t)(X509 *, unsigned char **); int err = 0; + BIO *fp = BIO_new_file(files[num], "r"); + + if (!TEST_ptr(fp)) + return 0; for (count = 0; !err && PEM_read_bio(fp, &name, &header, &data, &len); @@ -140,6 +148,7 @@ static int test_certs(BIO *fp) OPENSSL_free(header); OPENSSL_free(data); } + BIO_free(fp); if (ERR_GET_REASON(ERR_peek_last_error()) == PEM_R_NO_START_LINE) { /* Reached end of PEM file */ @@ -155,26 +164,12 @@ static int test_certs(BIO *fp) int test_main(int argc, char *argv[]) { - BIO *bio_err; - int ret = 1; - - if (argc < 2) + if (argc < 2) { TEST_error("usage: %s certfile...", argv[0]); - - bio_err = BIO_new_fp(stderr, BIO_NOCLOSE | BIO_FP_TEXT); - - for (argv++; *argv; argv++) { - BIO *f = BIO_new_file(*argv, "r"); - int ok; - - TEST_check(f != NULL); - ok = test_certs(f); - BIO_free(f); - - if (!TEST_int_eq(ok, 1)) - break; - ret = 0; + return 0; } - BIO_free(bio_err); - return ret; + + files = &argv[1]; + ADD_ALL_TESTS(test_certs, argc - 1); + return run_tests(argv[0]); } |