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 File
::Compare qw
/compare_text/;
15 use OpenSSL
::Test qw
/:DEFAULT/;
17 my %conversionforms = (
18 # Default conversion forms. Other series may be added with
19 # specific test types as key.
21 "msb" => [ "d", "p", "msblob" ],
22 "pvk" => [ "d", "p", "pvk" ],
27 die "Missing option -type" unless $opts{-type
};
28 die "Missing option -in" unless $opts{-in};
29 my $testtype = $opts{-type
};
31 my $prefix = $opts{-prefix
} // $testtype;
33 defined($conversionforms{$testtype}) ?
34 @
{$conversionforms{$testtype}} :
35 @
{$conversionforms{"*"}};
37 if (defined $opts{-args
}) {
38 @openssl_args = @
{$opts{-args
}} if ref $opts{-args
} eq 'ARRAY';
39 @openssl_args = ($opts{-args
}) if ref $opts{-args
} eq '';
41 @openssl_args = ($testtype) unless @openssl_args;
43 my $n = scalar @conversionforms;
46 + $n # initial conversions from p to all forms (A)
47 + $n*$n # conversion from result of A to all forms (B)
48 + 1 # comparing original test file to p form of A
49 + $n*($n-1); # comparing first conversion to each form in A with B
50 $totaltests-- if ($testtype eq "p7d"); # no comparison of original test file
51 $totaltests -= $n if ($testtype eq "pvk"); # no comparisons of the pvk form
52 plan tests
=> $totaltests;
54 my @cmd = ("openssl", @openssl_args);
57 if (scalar @openssl_args > 0 && $openssl_args[0] eq "pkey") {
58 $init = ok
(run
(app
([@cmd, "-in", $t, "-out", "$prefix-fff.p"])),
61 $init = ok
(copy
($t, "$prefix-fff.p"), 'initializing');
64 diag
("Trying to copy $t to $prefix-fff.p : $!");
68 skip
"Not initialized, skipping...", 22 unless $init;
70 foreach my $to (@conversionforms) {
72 "-in", "$prefix-fff.p",
74 "-out", "$prefix-f.$to",
79 foreach my $to (@conversionforms) {
80 foreach my $from (@conversionforms) {
82 "-in", "$prefix-f.$from",
84 "-out", "$prefix-ff.$from$to",
90 if ($testtype ne "p7d") {
91 is
(cmp_text
("$prefix-fff.p", "$prefix-f.p"), 0,
92 'comparing orig to p');
95 foreach my $to (@conversionforms) {
96 next if $to eq "d" or $to eq "pvk";
97 foreach my $from (@conversionforms) {
98 is
(cmp_text
("$prefix-f.$to", "$prefix-ff.$from$to"), 0,
99 "comparing $to to $from$to");
106 return compare_text
(@_, sub {
109 return $_[0] ne $_[1];
115 my $pattern = shift @_;
116 open(DATA
, $_) or return 0;
117 $_= join('', <DATA
>);
119 s/\s+/ /g; # take multiple whitespace (including newline) as single space
120 return m/$pattern/ ?
1 : 0;
125 my $pattern = shift @_;
126 my $expected = shift @_;
128 my $out = "cert_contains.out";
129 run
(app
(["openssl", "x509", "-noout", "-text", "-in", $cert, "-out", $out]));
130 is
(file_contains
($out, $pattern), $expected, ($name ?
"$name: " : "").
131 "$cert should ".($expected ?
"" : "not ")."contain: \"$pattern\"");
137 grep { not $seen{$_}++ } @_;
140 sub file_n_different_lines
{
141 my $filename = shift @_;
142 open(DATA
, $filename) or return 0;
143 chomp(my @lines = <DATA
>);
145 return scalar(uniq
@lines);
148 sub cert_ext_has_n_different_lines
{
150 my $expected = shift @_;
153 my $out = "cert_n_different_exts.out";
154 run
(app
(["openssl", "x509", "-noout", "-ext", $exts,
155 "-in", $cert, "-out", $out]));
156 is
(file_n_different_lines
($out), $expected, ($name ?
"$name: " : "").
157 "$cert '$exts' output should contain $expected different lines");