Raise an error on syscall failure in tls_retry_write_records
[openssl.git] / test / recipes / 65-test_cmp_msg.t
1 #! /usr/bin/env perl
2 # Copyright 2007-2020 The OpenSSL Project Authors. All Rights Reserved.
3 # Copyright Nokia 2007-2019
4 # Copyright Siemens AG 2015-2019
5 #
6 # Licensed under the Apache License 2.0 (the "License").  You may not use
7 # this file except in compliance with the License.  You can obtain a copy
8 # in the file LICENSE in the source distribution or at
9 # https://www.openssl.org/source/license.html
10
11 use strict;
12 use OpenSSL::Test qw/:DEFAULT data_file srctop_file srctop_dir bldtop_file bldtop_dir/;
13 use OpenSSL::Test::Utils;
14
15 BEGIN {
16     setup("test_cmp_msg");
17 }
18
19 use lib srctop_dir('Configurations');
20 use lib bldtop_dir('.');
21 use platform;
22
23 my $no_fips = disabled('fips') || ($ENV{NO_FIPS} // 0);
24
25 plan skip_all => "This test is not supported in a no-cmp build"
26     if disabled("cmp");
27
28 plan tests => 2 + ($no_fips ? 0 : 2); #fips install + fips test
29
30 my @basic_cmd = ("cmp_msg_test",
31                  data_file("new.key"),
32                  data_file("server.crt"),
33                  data_file("pkcs10.der"));
34
35 ok(run(test([@basic_cmd, "none"])));
36
37 ok(run(test([@basic_cmd, "default", srctop_file("test", "default.cnf")])));
38
39 unless ($no_fips) {
40     ok(run(app(['openssl', 'fipsinstall',
41                 '-out', bldtop_file('providers', 'fipsmodule.cnf'),
42                 '-module', bldtop_file('providers', platform->dso('fips'))])),
43        "fipsinstall");
44
45     ok(run(test([@basic_cmd,
46                  "fips", srctop_file("test", "fips-and-base.cnf")])));
47 }