2 # Copyright 2015-2021 The OpenSSL Project Authors. All Rights Reserved.
4 # Licensed under the Apache License 2.0 (the "License"). You may not use
5 # this file except in compliance with the License. You can obtain a copy
6 # in the file LICENSE in the source distribution or at
7 # https://www.openssl.org/source/license.html
13 use OpenSSL
::Test
::Utils
;
14 use OpenSSL
::Test qw
/:DEFAULT srctop_file/;
20 require_ok
(srctop_file
('test', 'recipes', 'tconversion.pl'));
22 my @certs = qw(test certs);
24 # What type of key to generate?
26 if (disabled
("rsa")) {
27 @req_new = ("-newkey", "dsa:".srctop_file
("apps", "dsa512.pem"));
30 note
("There should be a 2 sequences of .'s and some +'s.");
31 note
("There should not be more that at most 80 per line");
34 # Prevent MSys2 filename munging for arguments that look like file paths but
36 $ENV{MSYS2_ARG_CONV_EXCL
} = "/CN=";
38 # Check for duplicate -addext parameters, and one "working" case.
39 my @addext_args = ( "openssl", "req", "-new", "-out", "testreq.pem",
40 "-key", srctop_file
(@certs, "ee-key.pem"),
41 "-config", srctop_file
("test", "test.cnf"), @req_new );
42 my $val = "subjectAltName=DNS:example.com";
43 my $val2 = " " . $val;
46 ok
( run
(app
([@addext_args, "-addext", $val])));
47 ok
(!run
(app
([@addext_args, "-addext", $val, "-addext", $val])));
48 ok
(!run
(app
([@addext_args, "-addext", $val, "-addext", $val2])));
49 ok
(!run
(app
([@addext_args, "-addext", $val, "-addext", $val3])));
50 ok
(!run
(app
([@addext_args, "-addext", $val2, "-addext", $val3])));
52 # If a CSR is provided with neither of -key or -CA/-CAkey, this should fail.
53 ok
(!run
(app
(["openssl", "req", "-x509",
54 "-in", srctop_file
(@certs, "x509-check.csr"),
55 "-out", "testreq.pem"])));
57 subtest
"generating alt certificate requests with RSA" => sub {
61 skip
"RSA is not supported by this OpenSSL build", 2
64 ok
(run
(app
(["openssl", "req",
65 "-config", srctop_file
("test", "test.cnf"),
67 "-new", "-out", "testreq-rsa.pem", "-utf8",
68 "-key", srctop_file
("test", "testrsa.pem")])),
69 "Generating request");
71 ok
(run
(app
(["openssl", "req",
72 "-config", srctop_file
("test", "test.cnf"),
73 "-verify", "-in", "testreq-rsa.pem", "-noout"])),
74 "Verifying signature on request");
76 ok
(run
(app
(["openssl", "req",
77 "-config", srctop_file
("test", "test.cnf"),
79 "-verify", "-in", "testreq-rsa.pem", "-noout"])),
80 "Verifying signature on request");
85 subtest
"generating certificate requests with RSA" => sub {
89 skip
"RSA is not supported by this OpenSSL build", 2
92 ok
(!run
(app
(["openssl", "req",
93 "-config", srctop_file
("test", "test.cnf"),
94 "-new", "-out", "testreq-rsa.pem", "-utf8",
95 "-key", srctop_file
("test", "testrsa.pem"),
97 "Checking that mismatching keyform fails");
99 ok
(run
(app
(["openssl", "req",
100 "-config", srctop_file
("test", "test.cnf"),
101 "-new", "-out", "testreq-rsa.pem", "-utf8",
102 "-key", srctop_file
("test", "testrsa.pem"),
103 "-keyform", "PEM"])),
104 "Generating request");
106 ok
(run
(app
(["openssl", "req",
107 "-config", srctop_file
("test", "test.cnf"),
108 "-verify", "-in", "testreq-rsa.pem", "-noout"])),
109 "Verifying signature on request");
111 ok
(run
(app
(["openssl", "req",
112 "-config", srctop_file
("test", "test.cnf"),
113 "-modulus", "-in", "testreq-rsa.pem", "-noout"])),
114 "Printing a modulus of the request key");
116 ok
(run
(app
(["openssl", "req",
117 "-config", srctop_file
("test", "test.cnf"),
118 "-new", "-out", "testreq_withattrs_pem.pem", "-utf8",
119 "-key", srctop_file
("test", "testrsa_withattrs.pem")])),
120 "Generating request from a key with extra attributes - PEM");
122 ok
(run
(app
(["openssl", "req",
123 "-config", srctop_file
("test", "test.cnf"),
124 "-verify", "-in", "testreq_withattrs_pem.pem", "-noout"])),
125 "Verifying signature on request from a key with extra attributes - PEM");
127 ok
(run
(app
(["openssl", "req",
128 "-config", srctop_file
("test", "test.cnf"),
129 "-new", "-out", "testreq_withattrs_der.pem", "-utf8",
130 "-key", srctop_file
("test", "testrsa_withattrs.der"),
131 "-keyform", "DER"])),
132 "Generating request from a key with extra attributes - PEM");
134 ok
(run
(app
(["openssl", "req",
135 "-config", srctop_file
("test", "test.cnf"),
136 "-verify", "-in", "testreq_withattrs_der.pem", "-noout"])),
137 "Verifying signature on request from a key with extra attributes - PEM");
141 subtest
"generating certificate requests with RSA-PSS" => sub {
145 skip
"RSA is not supported by this OpenSSL build", 2
148 ok
(run
(app
(["openssl", "req",
149 "-config", srctop_file
("test", "test.cnf"),
150 "-new", "-out", "testreq-rsapss.pem", "-utf8",
151 "-key", srctop_file
("test", "testrsapss.pem")])),
152 "Generating request");
153 ok
(run
(app
(["openssl", "req",
154 "-config", srctop_file
("test", "test.cnf"),
155 "-verify", "-in", "testreq-rsapss.pem", "-noout"])),
156 "Verifying signature on request");
158 ok
(run
(app
(["openssl", "req",
159 "-config", srctop_file
("test", "test.cnf"),
160 "-new", "-out", "testreq-rsapss2.pem", "-utf8",
161 "-sigopt", "rsa_padding_mode:pss",
162 "-sigopt", "rsa_pss_saltlen:-1",
163 "-key", srctop_file
("test", "testrsapss.pem")])),
164 "Generating request");
165 ok
(run
(app
(["openssl", "req",
166 "-config", srctop_file
("test", "test.cnf"),
167 "-verify", "-in", "testreq-rsapss2.pem", "-noout"])),
168 "Verifying signature on request");
170 ok
(run
(app
(["openssl", "req",
171 "-config", srctop_file
("test", "test.cnf"),
172 "-new", "-out", "testreq-rsapssmand.pem", "-utf8",
173 "-sigopt", "rsa_padding_mode:pss",
174 "-key", srctop_file
("test", "testrsapssmandatory.pem")])),
175 "Generating request");
176 ok
(run
(app
(["openssl", "req",
177 "-config", srctop_file
("test", "test.cnf"),
178 "-verify", "-in", "testreq-rsapssmand.pem", "-noout"])),
179 "Verifying signature on request");
181 ok
(run
(app
(["openssl", "req",
182 "-config", srctop_file
("test", "test.cnf"),
183 "-new", "-out", "testreq-rsapssmand2.pem", "-utf8",
184 "-sigopt", "rsa_pss_saltlen:100",
185 "-key", srctop_file
("test", "testrsapssmandatory.pem")])),
186 "Generating request");
187 ok
(run
(app
(["openssl", "req",
188 "-config", srctop_file
("test", "test.cnf"),
189 "-verify", "-in", "testreq-rsapssmand2.pem", "-noout"])),
190 "Verifying signature on request");
192 ok
(!run
(app
(["openssl", "req",
193 "-config", srctop_file
("test", "test.cnf"),
194 "-new", "-out", "testreq-rsapss3.pem", "-utf8",
195 "-sigopt", "rsa_padding_mode:pkcs1",
196 "-key", srctop_file
("test", "testrsapss.pem")])),
197 "Generating request with expected failure");
199 ok
(!run
(app
(["openssl", "req",
200 "-config", srctop_file
("test", "test.cnf"),
201 "-new", "-out", "testreq-rsapss3.pem", "-utf8",
202 "-sigopt", "rsa_pss_saltlen:-4",
203 "-key", srctop_file
("test", "testrsapss.pem")])),
204 "Generating request with expected failure");
206 ok
(!run
(app
(["openssl", "req",
207 "-config", srctop_file
("test", "test.cnf"),
208 "-new", "-out", "testreq-rsapssmand3.pem", "-utf8",
209 "-sigopt", "rsa_pss_saltlen:10",
210 "-key", srctop_file
("test", "testrsapssmandatory.pem")])),
211 "Generating request with expected failure");
213 ok
(!run
(app
(["openssl", "req",
214 "-config", srctop_file
("test", "test.cnf"),
215 "-new", "-out", "testreq-rsapssmand3.pem", "-utf8",
217 "-key", srctop_file
("test", "testrsapssmandatory.pem")])),
218 "Generating request with expected failure");
222 subtest
"generating certificate requests with DSA" => sub {
226 skip
"DSA is not supported by this OpenSSL build", 2
229 ok
(run
(app
(["openssl", "req",
230 "-config", srctop_file
("test", "test.cnf"),
231 "-new", "-out", "testreq-dsa.pem", "-utf8",
232 "-key", srctop_file
("test", "testdsa.pem")])),
233 "Generating request");
235 ok
(run
(app
(["openssl", "req",
236 "-config", srctop_file
("test", "test.cnf"),
237 "-verify", "-in", "testreq-dsa.pem", "-noout"])),
238 "Verifying signature on request");
242 subtest
"generating certificate requests with ECDSA" => sub {
246 skip
"ECDSA is not supported by this OpenSSL build", 2
249 ok
(run
(app
(["openssl", "req",
250 "-config", srctop_file
("test", "test.cnf"),
251 "-new", "-out", "testreq-ec.pem", "-utf8",
252 "-key", srctop_file
("test", "testec-p256.pem")])),
253 "Generating request");
255 ok
(run
(app
(["openssl", "req",
256 "-config", srctop_file
("test", "test.cnf"),
257 "-verify", "-in", "testreq-ec.pem", "-noout"])),
258 "Verifying signature on request");
262 subtest
"generating certificate requests with Ed25519" => sub {
266 skip
"Ed25519 is not supported by this OpenSSL build", 2
269 ok
(run
(app
(["openssl", "req",
270 "-config", srctop_file
("test", "test.cnf"),
271 "-new", "-out", "testreq-ed25519.pem", "-utf8",
272 "-key", srctop_file
("test", "tested25519.pem")])),
273 "Generating request");
275 ok
(run
(app
(["openssl", "req",
276 "-config", srctop_file
("test", "test.cnf"),
277 "-verify", "-in", "testreq-ed25519.pem", "-noout"])),
278 "Verifying signature on request");
282 subtest
"generating certificate requests with Ed448" => sub {
286 skip
"Ed448 is not supported by this OpenSSL build", 2
289 ok
(run
(app
(["openssl", "req",
290 "-config", srctop_file
("test", "test.cnf"),
291 "-new", "-out", "testreq-ed448.pem", "-utf8",
292 "-key", srctop_file
("test", "tested448.pem")])),
293 "Generating request");
295 ok
(run
(app
(["openssl", "req",
296 "-config", srctop_file
("test", "test.cnf"),
297 "-verify", "-in", "testreq-ed448.pem", "-noout"])),
298 "Verifying signature on request");
302 subtest
"generating certificate requests" => sub {
305 ok
(run
(app
(["openssl", "req", "-config", srctop_file
("test", "test.cnf"),
306 "-key", srctop_file
(@certs, "ee-key.pem"),
307 @req_new, "-out", "testreq.pem"])),
308 "Generating request");
310 ok
(run
(app
(["openssl", "req", "-config", srctop_file
("test", "test.cnf"),
311 "-verify", "-in", "testreq.pem", "-noout"])),
312 "Verifying signature on request");
315 subtest
"generating SM2 certificate requests" => sub {
319 skip
"SM2 is not supported by this OpenSSL build", 4
321 ok
(run
(app
(["openssl", "req",
322 "-config", srctop_file
("test", "test.cnf"),
323 "-new", "-key", srctop_file
(@certs, "sm2.key"),
324 "-sigopt", "distid:1234567812345678",
325 "-out", "testreq-sm2.pem", "-sm3"])),
326 "Generating SM2 certificate request");
328 ok
(run
(app
(["openssl", "req",
329 "-config", srctop_file
("test", "test.cnf"),
330 "-verify", "-in", "testreq-sm2.pem", "-noout",
331 "-vfyopt", "distid:1234567812345678", "-sm3"])),
332 "Verifying signature on SM2 certificate request");
334 ok
(run
(app
(["openssl", "req",
335 "-config", srctop_file
("test", "test.cnf"),
336 "-new", "-key", srctop_file
(@certs, "sm2.key"),
337 "-sigopt", "hexdistid:DEADBEEF",
338 "-out", "testreq-sm2.pem", "-sm3"])),
339 "Generating SM2 certificate request with hex id");
341 ok
(run
(app
(["openssl", "req",
342 "-config", srctop_file
("test", "test.cnf"),
343 "-verify", "-in", "testreq-sm2.pem", "-noout",
344 "-vfyopt", "hexdistid:DEADBEEF", "-sm3"])),
345 "Verifying signature on SM2 certificate request");
349 my @openssl_args = ("req", "-config", srctop_file
("apps", "openssl.cnf"));
351 run_conversion
('req conversions',
353 run_conversion
('req conversions -- testreq2',
354 srctop_file
("test", "testreq2.pem"));
360 subtest
$title => sub {
361 run
(app
(["openssl", @openssl_args,
362 "-in", $reqfile, "-inform", "p",
364 stderr
=> "req-check.err", stdout
=> undef));
365 open DATA
, "req-check.err";
367 plan skip_all
=> "skipping req conversion test for $reqfile"
368 if grep /Unknown Public Key/, map { s/\R//; } <DATA
>;
370 tconversion
( -type
=> 'req', -in => $reqfile,
371 -args
=> [ @openssl_args ] );
374 unlink "req-check.err";
380 # Test both generation and verification of certs w.r.t. RFC 5280 requirements
382 my $ca_cert; # will be set below
385 my $ss = $cert =~ m/self-signed/;
386 my $is_ca = $cert =~ m/CA/;
387 my $cn = $is_ca ?
"CA" : "EE";
388 my $ca_key = srctop_file
(@certs, "ca-key.pem");
389 my $key = $is_ca ?
$ca_key : srctop_file
(@certs, "ee-key.pem");
390 my @cmd = ("openssl", "req", "-config", "", "-x509",
391 "-subj", "/CN=$cn", @_, "-out", $cert);
392 push(@cmd, ("-key", $key)) if $ss;
393 push(@cmd, ("-CA", $ca_cert, "-CAkey", $ca_key)) unless $ss;
394 ok
(run
(app
([@cmd])), "generate $cert");
398 my $expect = shift @_;
399 cert_contains
($cert, "Subject Key Identifier", $expect);
403 my $expect = shift @_;
404 cert_contains
($cert, "Authority Key Identifier", $expect);
408 my $expect = shift @_;
409 cert_contains
($cert, "Key Usage", $expect);
413 my $expect = shift @_;
414 my $trusted = shift @_;
415 $trusted = $cert unless $trusted;
416 ok
(run
(app
(["openssl", "verify", "-x509_strict", "-trusted", $trusted,
417 "-partial_chain", $cert])) == $expect,
418 "strict verify allow $cert");
421 my @v3_ca = ("-addext", "basicConstraints = critical,CA:true",
422 "-addext", "keyUsage = keyCertSign");
423 my $SKID_AKID = "subjectKeyIdentifier,authorityKeyIdentifier";
427 my $cert = "self-signed_v3_CA_hash_SKID.pem";
428 generate_cert
($cert, @v3_ca, "-addext", "subjectKeyIdentifier = hash");
429 has_SKID
($cert, 1); # explicit hash SKID
431 $cert = "self-signed_v3_CA_no_SKID.pem";
432 generate_cert
($cert, @v3_ca, "-addext", "subjectKeyIdentifier = none");
433 cert_ext_has_n_different_lines
($cert, 0, $SKID_AKID); # no SKID and no AKID
434 #TODO strict_verify($cert, 0);
436 $cert = "self-signed_v3_CA_given_SKID.pem";
437 generate_cert
($cert, @v3_ca, "-addext", "subjectKeyIdentifier = 45");
438 cert_contains
($cert, "Subject Key Identifier: 45 ", 1); # given SKID
439 strict_verify
($cert, 1);
441 # AKID of self-signed certs
443 $cert = "self-signed_v1_CA_no_KIDs.pem";
444 generate_cert
($cert);
445 cert_ext_has_n_different_lines
($cert, 0, $SKID_AKID); # no SKID and no AKID
446 #TODO strict_verify($cert, 1); # self-signed v1 root cert should be accepted as CA
448 $ca_cert = "self-signed_v3_CA_default_SKID.pem"; # will also be used below
449 generate_cert
($ca_cert, @v3_ca);
450 has_SKID
($ca_cert, 1); # default SKID
451 has_AKID
($ca_cert, 0); # no default AKID
452 strict_verify
($ca_cert, 1);
454 $cert = "self-signed_v3_CA_no_AKID.pem";
455 generate_cert
($cert, @v3_ca, "-addext", "authorityKeyIdentifier = none");
456 has_AKID
($cert, 0); # forced no AKID
458 $cert = "self-signed_v3_CA_explicit_AKID.pem";
459 generate_cert
($cert, @v3_ca, "-addext", "authorityKeyIdentifier = keyid");
460 has_AKID
($cert, 0); # for self-signed cert, AKID suppressed and not forced
462 $cert = "self-signed_v3_CA_forced_AKID.pem";
463 generate_cert
($cert, @v3_ca, "-addext", "authorityKeyIdentifier = keyid:always");
464 cert_ext_has_n_different_lines
($cert, 3, $SKID_AKID); # forced AKID, AKID == SKID
465 strict_verify
($cert, 1);
467 $cert = "self-signed_v3_CA_issuer_AKID.pem";
468 generate_cert
($cert, @v3_ca, "-addext", "authorityKeyIdentifier = issuer");
469 has_AKID
($cert, 0); # suppressed AKID since not forced
471 $cert = "self-signed_v3_CA_forced_issuer_AKID.pem";
472 generate_cert
($cert, @v3_ca, "-addext", "authorityKeyIdentifier = issuer:always");
473 cert_contains
($cert, "Authority Key Identifier: DirName:/CN=CA serial:", 1); # forced issuer AKID
475 $cert = "self-signed_v3_CA_nonforced_keyid_issuer_AKID.pem";
476 generate_cert
($cert, @v3_ca, "-addext", "authorityKeyIdentifier = keyid, issuer");
477 has_AKID
($cert, 0); # AKID not present because not forced and cert self-signed
479 $cert = "self-signed_v3_CA_keyid_forced_issuer_AKID.pem";
480 generate_cert
($cert, @v3_ca, "-addext", "authorityKeyIdentifier = keyid, issuer:always");
481 cert_contains
($cert, "Authority Key Identifier: DirName:/CN=CA serial:", 1); # issuer AKID forced, with keyid not forced
483 $cert = "self-signed_v3_CA_forced_keyid_issuer_AKID.pem";
484 generate_cert
($cert, @v3_ca, "-addext", "authorityKeyIdentifier = keyid:always, issuer");
485 has_AKID
($cert, 1); # AKID with keyid forced
486 cert_contains
($cert, "Authority Key Identifier: DirName:/CN=CA serial:", 0); # no issuer AKID
488 $cert = "self-signed_v3_CA_forced_keyid_forced_issuer_AKID.pem";
489 generate_cert
($cert, @v3_ca, "-addext", "authorityKeyIdentifier = keyid:always, issuer:always");
490 cert_contains
($cert, "Authority Key Identifier: keyid(:[0-9A-Fa-f]{2})+ DirName:/CN=CA serial:", 1); # AKID with keyid and issuer forced
492 $cert = "self-signed_v3_EE_wrong_keyUsage.pem";
493 generate_cert
($cert, "-addext", "keyUsage = keyCertSign");
494 #TODO strict_verify($cert, 1); # should be accepted because RFC 5280 does not apply
496 # AKID of self-issued but not self-signed certs
498 $cert = "self-issued_x509_v3_CA_default_KIDs.pem";
499 ok
(run
(app
([("openssl", "x509", "-copy_extensions", "copy",
500 "-req", "-in", srctop_file
(@certs, "ext-check.csr"),
501 "-key", srctop_file
(@certs, "ca-key.pem"),
502 "-force_pubkey", srctop_file
("test", "testrsapub.pem"),
503 "-out", $cert)])), "generate using x509: $cert");
504 cert_contains
($cert, "Issuer: CN=test .*? Subject: CN=test", 1);
505 cert_ext_has_n_different_lines
($cert, 4, $SKID_AKID); # SKID != AKID
506 strict_verify
($cert, 1);
508 $cert = "self-issued_v3_CA_default_KIDs.pem";
509 generate_cert
($cert, "-addext", "keyUsage = dataEncipherment",
510 "-in", srctop_file
(@certs, "x509-check.csr"));
511 cert_contains
($cert, "Issuer: CN=CA .*? Subject: CN=CA", 1);
512 cert_ext_has_n_different_lines
($cert, 4, $SKID_AKID); # SKID != AKID
513 strict_verify
($cert, 1);
515 $cert = "self-issued_v3_CA_no_AKID.pem";
516 generate_cert
($cert, "-addext", "authorityKeyIdentifier = none",
517 "-in", srctop_file
(@certs, "x509-check.csr"));
519 strict_verify
($cert, 1);
521 $cert = "self-issued_v3_CA_explicit_AKID.pem";
522 generate_cert
($cert, "-addext", "authorityKeyIdentifier = keyid",
523 "-in", srctop_file
(@certs, "x509-check.csr"));
524 cert_ext_has_n_different_lines
($cert, 4, $SKID_AKID); # SKID != AKID
525 strict_verify
($cert, 1);
527 $cert = "self-issued_v3_CA_forced_AKID.pem";
528 generate_cert
($cert, "-addext", "authorityKeyIdentifier = keyid:always",
529 "-in", srctop_file
(@certs, "x509-check.csr"));
530 cert_ext_has_n_different_lines
($cert, 4, $SKID_AKID); # SKID != AKID
532 $cert = "self-issued_v3_CA_issuer_AKID.pem";
533 generate_cert
($cert, @v3_ca, "-addext", "authorityKeyIdentifier = issuer",
534 "-in", srctop_file
(@certs, "x509-check.csr"));
535 cert_contains
($cert, "Authority Key Identifier: DirName:/CN=CA serial:", 1); # just issuer AKID
537 $cert = "self-issued_v3_CA_forced_issuer_AKID.pem";
538 generate_cert
($cert, @v3_ca, "-addext", "authorityKeyIdentifier = issuer:always",
539 "-in", srctop_file
(@certs, "x509-check.csr"));
540 cert_contains
($cert, "Authority Key Identifier: DirName:/CN=CA serial:", 1); # just issuer AKID
542 $cert = "self-issued_v3_CA_keyid_issuer_AKID.pem";
543 generate_cert
($cert, "-addext", "authorityKeyIdentifier = keyid, issuer",
544 "-in", srctop_file
(@certs, "x509-check.csr"));
545 cert_ext_has_n_different_lines
($cert, 4, $SKID_AKID); # SKID != AKID, not forced
547 $cert = "self-issued_v3_CA_keyid_forced_issuer_AKID.pem";
548 generate_cert
($cert, "-addext", "authorityKeyIdentifier = keyid, issuer:always",
549 "-in", srctop_file
(@certs, "x509-check.csr"));
550 cert_ext_has_n_different_lines
($cert, 6, $SKID_AKID); # SKID != AKID, with forced issuer
552 $cert = "self-issued_v3_CA_forced_keyid_and_issuer_AKID.pem";
553 generate_cert
($cert, "-addext", "authorityKeyIdentifier = keyid:always, issuer:always",
554 "-in", srctop_file
(@certs, "x509-check.csr"));
555 cert_ext_has_n_different_lines
($cert, 6, $SKID_AKID); # SKID != AKID, both forced
557 # AKID of not self-issued certs
559 $cert = "regular_v3_EE_default_KIDs.pem";
560 generate_cert
($cert, "-addext", "keyUsage = dataEncipherment",
561 "-key", srctop_file
(@certs, "ee-key.pem"));
562 cert_ext_has_n_different_lines
($cert, 4, $SKID_AKID); # SKID != AKID
563 strict_verify
($cert, 1, $ca_cert);
565 $cert = "regular_v3_EE_copied_exts_default_KIDs.pem";
566 generate_cert
($cert, "-copy_extensions", "copy",
567 "-in", srctop_file
(@certs, "ext-check.csr"));
568 cert_ext_has_n_different_lines
($cert, 4, $SKID_AKID); # SKID != AKID
569 strict_verify
($cert, 1);
571 $cert = "v3_EE_no_AKID.pem";
572 generate_cert
($cert, "-addext", "authorityKeyIdentifier = none",
573 "-key", srctop_file
(@certs, "ee-key.pem"));
576 strict_verify
($cert, 0, $ca_cert);
581 $cert = "self-signed_CA_no_keyUsage.pem";
582 generate_cert
($cert, "-in", srctop_file
(@certs, "ext-check.csr"));
583 has_keyUsage
($cert, 0);
584 $cert = "self-signed_CA_with_keyUsages.pem";
585 generate_cert
($cert, "-in", srctop_file
(@certs, "ext-check.csr"),
586 "-copy_extensions", "copy");
587 has_keyUsage
($cert, 1);