]>
Commit | Line | Data |
---|---|---|
596d6b7e | 1 | #! /usr/bin/env perl |
1212818e | 2 | # Copyright 2015-2018 The OpenSSL Project Authors. All Rights Reserved. |
596d6b7e | 3 | # |
909f1a2e | 4 | # Licensed under the Apache License 2.0 (the "License"). You may not use |
596d6b7e RS |
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 | |
8 | ||
4650de3e RL |
9 | |
10 | use strict; | |
11 | use warnings; | |
12 | ||
e2ec7332 | 13 | use OpenSSL::Test::Utils; |
42e0ccdf | 14 | use OpenSSL::Test qw/:DEFAULT srctop_file/; |
4650de3e RL |
15 | |
16 | setup("test_req"); | |
17 | ||
f9964863 | 18 | plan tests => 9; |
4650de3e | 19 | |
42e0ccdf | 20 | require_ok(srctop_file('test','recipes','tconversion.pl')); |
4650de3e | 21 | |
e2ec7332 | 22 | open RND, ">>", ".rnd"; |
f367ac2b | 23 | print RND "string to make the random number generator think it has randomness"; |
e2ec7332 | 24 | close RND; |
2ddee136 | 25 | |
f9964863 RS |
26 | # What type of key to generate? |
27 | my @req_new; | |
28 | if (disabled("rsa")) { | |
29 | @req_new = ("-newkey", "dsa:".srctop_file("apps", "dsa512.pem")); | |
30 | } else { | |
31 | @req_new = ("-new"); | |
32 | note("There should be a 2 sequences of .'s and some +'s."); | |
33 | note("There should not be more that at most 80 per line"); | |
34 | } | |
35 | ||
36 | # Check for duplicate -addext parameters, and one "working" case. | |
37 | my @addext_args = ( "openssl", "req", "-new", "-out", "testreq.pem", | |
38 | "-config", srctop_file("test", "test.cnf"), @req_new ); | |
2ddee136 RS |
39 | my $val = "subjectAltName=DNS:example.com"; |
40 | my $val2 = " " . $val; | |
41 | my $val3 = $val; | |
42 | $val3 =~ s/=/ =/; | |
f9964863 RS |
43 | ok( run(app([@addext_args, "-addext", $val]))); |
44 | ok(!run(app([@addext_args, "-addext", $val, "-addext", $val]))); | |
45 | ok(!run(app([@addext_args, "-addext", $val, "-addext", $val2]))); | |
46 | ok(!run(app([@addext_args, "-addext", $val, "-addext", $val3]))); | |
47 | ok(!run(app([@addext_args, "-addext", $val2, "-addext", $val3]))); | |
2ddee136 | 48 | |
e2ec7332 | 49 | subtest "generating certificate requests" => sub { |
e2ec7332 RL |
50 | plan tests => 2; |
51 | ||
52 | ok(run(app(["openssl", "req", "-config", srctop_file("test", "test.cnf"), | |
53 | @req_new, "-out", "testreq.pem"])), | |
54 | "Generating request"); | |
55 | ||
56 | ok(run(app(["openssl", "req", "-config", srctop_file("test", "test.cnf"), | |
57 | "-verify", "-in", "testreq.pem", "-noout"])), | |
58 | "Verifying signature on request"); | |
59 | }; | |
60 | ||
42e0ccdf | 61 | my @openssl_args = ("req", "-config", srctop_file("apps", "openssl.cnf")); |
4650de3e RL |
62 | |
63 | run_conversion('req conversions', | |
64 | "testreq.pem"); | |
65 | run_conversion('req conversions -- testreq2', | |
e2ec7332 RL |
66 | srctop_file("test", "testreq2.pem")); |
67 | ||
68 | unlink "testkey.pem", "testreq.pem"; | |
4650de3e RL |
69 | |
70 | sub run_conversion { | |
71 | my $title = shift; | |
72 | my $reqfile = shift; | |
73 | ||
74 | subtest $title => sub { | |
75 | run(app(["openssl", @openssl_args, | |
76 | "-in", $reqfile, "-inform", "p", | |
77 | "-noout", "-text"], | |
78 | stderr => "req-check.err", stdout => undef)); | |
79 | open DATA, "req-check.err"; | |
80 | SKIP: { | |
81 | plan skip_all => "skipping req conversion test for $reqfile" | |
85833408 | 82 | if grep /Unknown Public Key/, map { s/\R//; } <DATA>; |
4650de3e | 83 | |
e2ec7332 | 84 | tconversion("req", $reqfile, @openssl_args); |
4650de3e RL |
85 | } |
86 | close DATA; | |
87 | unlink "req-check.err"; | |
88 | ||
89 | done_testing(); | |
90 | }; | |
91 | } |