]> git.ipfire.org Git - thirdparty/openssl.git/blame - test/recipes/30-test_evp.t
Update some nits around the FIPS module
[thirdparty/openssl.git] / test / recipes / 30-test_evp.t
CommitLineData
596d6b7e 1#! /usr/bin/env perl
33388b44 2# Copyright 2015-2020 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
4fb35f8f
RL
9
10use strict;
11use warnings;
12
7bb82f92 13use OpenSSL::Test qw(:DEFAULT data_file bldtop_dir srctop_file srctop_dir bldtop_file);
23ccf13d 14use OpenSSL::Test::Utils;
4fb35f8f 15
7bb82f92 16BEGIN {
4fb35f8f 17setup("test_evp");
7bb82f92
SL
18}
19
20use lib srctop_dir('Configurations');
21use lib bldtop_dir('.');
22use platform;
4fb35f8f 23
e0d952fc
RL
24my $no_fips = disabled('fips') || ($ENV{NO_FIPS} // 0);
25my $no_legacy = disabled('legacy') || ($ENV{NO_LEGACY} // 0);
26
23ccf13d 27# Default config depends on if the legacy module is built or not
e0d952fc 28my $defaultcnf = $no_legacy ? 'default.cnf' : 'default-and-legacy.cnf';
23ccf13d
RL
29
30my @configs = ( $defaultcnf );
31# Only add the FIPS config if the FIPS module has been built
e0d952fc 32push @configs, 'fips.cnf' unless $no_fips;
23ccf13d 33
1c725f46 34my @files = qw( evpciph.txt evpdigest.txt evppkey.txt evppkey_ecc.txt);
f305ecda 35my @defltfiles = qw( evpencod.txt evpkdf.txt evppkey_kdf.txt evpmac.txt
1c725f46 36 evppbe.txt evpcase.txt evpccmcavs.txt );
f22431f2
SL
37my @ideafiles = qw( evpciph_idea.txt );
38push @defltfiles, @ideafiles unless disabled("idea");
6b7b3433 39
eb173822
SL
40my @sivfiles = qw( evpaessiv.txt );
41push @defltfiles, @sivfiles unless disabled("siv");
42
18b00427
SL
43my @castfiles = qw( evpciph_cast5.txt );
44push @defltfiles, @castfiles unless disabled("cast");
45
70adc646
SL
46my @seedfiles = qw( evpciph_seed.txt );
47push @defltfiles, @seedfiles unless disabled("seed");
48
105dde25
SL
49my @sm4files = qw( evpciph_sm4.txt );
50push @defltfiles, @sm4files unless disabled("sm4");
51
e3f3ee44
SL
52my @desfiles = qw( evpciph_des.txt );
53push @defltfiles, @desfiles unless disabled("des");
54
bafde183
SL
55my @rc4files = qw( evpciph_rc4.txt );
56push @defltfiles, @rc4files unless disabled("rc4");
57
6a41156c
SL
58my @rc5files = qw( evpciph_rc5.txt );
59push @defltfiles, @rc5files unless disabled("rc5");
60
f816aa47
SL
61my @rc2files = qw( evpciph_rc2.txt );
62push @defltfiles, @rc2files unless disabled("rc2");
63
3d5a7578
SL
64my @chachafiles = qw( evpciph_chacha.txt );
65push @defltfiles, @chachafiles unless disabled("chacha");
66
18385800
MC
67my @bffiles = qw( evpciph_bf.txt );
68push @defltfiles, @bffiles unless disabled("bf");
69
4ff5b41a
RL
70my @md2files = qw( evpmd_md2.txt );
71push @defltfiles, @md2files unless disabled("md2");
d3ac2eab 72
4ff5b41a
RL
73my @mdc2files = qw( evpmd_mdc2.txt );
74push @defltfiles, @mdc2files unless disabled("mdc2");
ed5cb177 75
e0d952fc
RL
76plan tests =>
77 ($no_fips ? 0 : 1) # FIPS install test
78 + (scalar(@configs) * scalar(@files))
79 + scalar(@defltfiles);
80
81unless ($no_fips) {
1e78a50f 82 my $infile = bldtop_file('providers', platform->dso('fips'));
e0d952fc
RL
83 $ENV{OPENSSL_MODULES} = bldtop_dir("providers");
84 $ENV{OPENSSL_CONF_INCLUDE} = bldtop_dir("providers");
85
1e78a50f 86 ok(run(app(['openssl', 'fipsinstall',
1cd2c1f8 87 '-out', bldtop_file('providers', 'fipsmodule.cnf'),
1e78a50f
RL
88 '-module', $infile,
89 '-provider_name', 'fips', '-mac_name', 'HMAC',
90 '-macopt', 'digest:SHA256', '-macopt', 'hexkey:00',
91 '-section_name', 'fips_sect'])),
be3acd79 92 "fipsinstall");
e0d952fc 93}
6b7b3433 94
e2f72313
RL
95foreach (@configs) {
96 $ENV{OPENSSL_CONF} = srctop_file("test", $_);
97
98 foreach my $f ( @files ) {
99 ok(run(test(["evp_test", data_file("$f")])),
100 "running evp_test $f");
101 }
6b7b3433 102}
f305ecda
MC
103
104#TODO(3.0): As more operations are converted to providers we can move more of
105# these tests to the loop above
106
23ccf13d 107$ENV{OPENSSL_CONF} = srctop_file("test", $defaultcnf);
f305ecda
MC
108
109foreach my $f ( @defltfiles ) {
110 ok(run(test(["evp_test", data_file("$f")])),
111 "running evp_test $f");
112}