xref: /freebsd/crypto/openssl/test/x509_load_cert_file_test.c (revision e7be843b4a162e68651d3911f0357ed464915629)
1*e7be843bSPierre Pronchery /*
2*e7be843bSPierre Pronchery  * Licensed under the Apache License 2.0 (the "License").  You may not use
3*e7be843bSPierre Pronchery  * this file except in compliance with the License.  You can obtain a copy
4*e7be843bSPierre Pronchery  * in the file LICENSE in the source distribution or at
5*e7be843bSPierre Pronchery  * https://www.openssl.org/source/license.html
6*e7be843bSPierre Pronchery  */
7*e7be843bSPierre Pronchery 
8*e7be843bSPierre Pronchery #include <stdio.h>
9*e7be843bSPierre Pronchery #include <openssl/err.h>
10*e7be843bSPierre Pronchery #include <openssl/x509_vfy.h>
11*e7be843bSPierre Pronchery 
12*e7be843bSPierre Pronchery #include "testutil.h"
13*e7be843bSPierre Pronchery 
14*e7be843bSPierre Pronchery static const char *chain;
15*e7be843bSPierre Pronchery static const char *crl;
16*e7be843bSPierre Pronchery 
test_load_cert_file(void)17*e7be843bSPierre Pronchery static int test_load_cert_file(void)
18*e7be843bSPierre Pronchery {
19*e7be843bSPierre Pronchery     int ret = 0, i;
20*e7be843bSPierre Pronchery     X509_STORE *store = NULL;
21*e7be843bSPierre Pronchery     X509_LOOKUP *lookup = NULL;
22*e7be843bSPierre Pronchery     STACK_OF(X509) *certs = NULL;
23*e7be843bSPierre Pronchery     STACK_OF(X509_OBJECT) *objs = NULL;
24*e7be843bSPierre Pronchery 
25*e7be843bSPierre Pronchery     if (!TEST_ptr(store = X509_STORE_new())
26*e7be843bSPierre Pronchery         || !TEST_ptr(lookup = X509_STORE_add_lookup(store, X509_LOOKUP_file()))
27*e7be843bSPierre Pronchery         || !TEST_true(X509_load_cert_file(lookup, chain, X509_FILETYPE_PEM))
28*e7be843bSPierre Pronchery         || !TEST_ptr(certs = X509_STORE_get1_all_certs(store))
29*e7be843bSPierre Pronchery         || !TEST_int_eq(sk_X509_num(certs), 4)
30*e7be843bSPierre Pronchery         || !TEST_ptr(objs = X509_STORE_get1_objects(store))
31*e7be843bSPierre Pronchery         || !TEST_int_eq(sk_X509_OBJECT_num(objs), 4))
32*e7be843bSPierre Pronchery         goto err;
33*e7be843bSPierre Pronchery 
34*e7be843bSPierre Pronchery     for (i = 0; i < sk_X509_OBJECT_num(objs); i++) {
35*e7be843bSPierre Pronchery         const X509_OBJECT *obj = sk_X509_OBJECT_value(objs, i);
36*e7be843bSPierre Pronchery         if (!TEST_int_eq(X509_OBJECT_get_type(obj), X509_LU_X509))
37*e7be843bSPierre Pronchery             goto err;
38*e7be843bSPierre Pronchery     }
39*e7be843bSPierre Pronchery 
40*e7be843bSPierre Pronchery     if (crl != NULL && !TEST_true(X509_load_crl_file(lookup, crl, X509_FILETYPE_PEM)))
41*e7be843bSPierre Pronchery         goto err;
42*e7be843bSPierre Pronchery 
43*e7be843bSPierre Pronchery     ret = 1;
44*e7be843bSPierre Pronchery 
45*e7be843bSPierre Pronchery err:
46*e7be843bSPierre Pronchery     OSSL_STACK_OF_X509_free(certs);
47*e7be843bSPierre Pronchery     sk_X509_OBJECT_pop_free(objs, X509_OBJECT_free);
48*e7be843bSPierre Pronchery     X509_STORE_free(store);
49*e7be843bSPierre Pronchery     return ret;
50*e7be843bSPierre Pronchery }
51*e7be843bSPierre Pronchery 
52*e7be843bSPierre Pronchery OPT_TEST_DECLARE_USAGE("cert.pem [crl.pem]\n")
53*e7be843bSPierre Pronchery 
setup_tests(void)54*e7be843bSPierre Pronchery int setup_tests(void)
55*e7be843bSPierre Pronchery {
56*e7be843bSPierre Pronchery     if (!test_skip_common_options()) {
57*e7be843bSPierre Pronchery         TEST_error("Error parsing test options\n");
58*e7be843bSPierre Pronchery         return 0;
59*e7be843bSPierre Pronchery     }
60*e7be843bSPierre Pronchery 
61*e7be843bSPierre Pronchery     chain = test_get_argument(0);
62*e7be843bSPierre Pronchery     if (chain == NULL)
63*e7be843bSPierre Pronchery         return 0;
64*e7be843bSPierre Pronchery 
65*e7be843bSPierre Pronchery     crl = test_get_argument(1);
66*e7be843bSPierre Pronchery 
67*e7be843bSPierre Pronchery     ADD_TEST(test_load_cert_file);
68*e7be843bSPierre Pronchery     return 1;
69*e7be843bSPierre Pronchery }
70