2 # Copyright 2016-2018 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
10 use OpenSSL::Test::Utils;
11 use OpenSSL::Test qw/:DEFAULT srctop_file srctop_dir bldtop_dir bldtop_file/;
12 use File::Temp qw(tempfile);
18 use lib srctop_dir('Configurations');
19 use lib bldtop_dir('.');
22 my $no_fips = disabled('fips') || ($ENV{NO_FIPS} // 0);
24 plan skip_all => "No TLS/SSL protocols are supported by this OpenSSL build"
25 if alldisabled(grep { $_ ne "ssl3" } available_protocols("tls"));
28 ($no_fips ? 0 : 2) # FIPS install test + sslapitest with fips
29 + 1; # sslapitest with default provider
31 (undef, my $tmpfilename) = tempfile();
33 $ENV{OPENSSL_MODULES} = bldtop_dir("providers");
34 $ENV{OPENSSL_CONF_INCLUDE} = bldtop_dir("providers");
36 ok(run(test(["sslapitest", srctop_dir("test", "certs"),
37 srctop_file("test", "recipes", "90-test_sslapi_data",
38 "passwd.txt"), $tmpfilename, "default",
39 srctop_file("test", "default.cnf")])),
40 "running sslapitest");
43 ok(run(app(['openssl', 'fipsinstall',
44 '-out', bldtop_file('providers', 'fipsinstall.cnf'),
45 '-module', bldtop_file('providers', platform->dso('fips')),
46 '-provider_name', 'fips', '-mac_name', 'HMAC',
47 '-macopt', 'digest:SHA256', '-macopt', 'hexkey:00',
48 '-section_name', 'fips_sect'])),
51 ok(run(test(["sslapitest", srctop_dir("test", "certs"),
52 srctop_file("test", "recipes", "90-test_sslapi_data",
53 "passwd.txt"), $tmpfilename, "fips",
54 srctop_file("test", "fips.cnf")])),
55 "running sslapitest");