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