summaryrefslogtreecommitdiff
path: root/test/x509aux.c
diff options
context:
space:
mode:
authorRich Salz <rsalz@openssl.org>2017-04-12 09:27:33 -0400
committerRich Salz <rsalz@openssl.org>2017-04-12 11:20:48 -0400
commitf1e793cc974094da7da52c6958ad7b972b4a446d (patch)
tree90abed20172c2f707f211c77f2b5fa7e45e90c47 /test/x509aux.c
parente2a29ad6c5f6b42ce71400595cb504cbf8f3646a (diff)
downloadopenssl-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.c37
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]);
}