#! /usr/bin/env perl
# Copyright 2007-2020 The OpenSSL Project Authors. All Rights Reserved.
# Copyright Nokia 2007-2019
# Copyright Siemens AG 2015-2019
#
# Licensed under the Apache License 2.0 (the "License").  You may not use
# this file except in compliance with the License.  You can obtain a copy
# in the file LICENSE in the source distribution or at
# https://www.openssl.org/source/license.html

use strict;
use OpenSSL::Test qw/:DEFAULT data_file srctop_file srctop_dir bldtop_file bldtop_dir/;
use OpenSSL::Test::Utils;

BEGIN {
    setup("test_cmp_vfy");
}

use lib srctop_dir('Configurations');
use lib bldtop_dir('.');
use platform;

my $no_fips = disabled('fips') || ($ENV{NO_FIPS} // 0);

plan skip_all => "This test is not supported in a no-cmp build"
    if disabled("cmp");

plan skip_all => "This test is not supported in a no-ec build"
    if disabled("ec");

plan tests => 2 + ($no_fips ? 0 : 2); #fips install + fips test

my @basic_cmd = ("cmp_vfy_test",
                 data_file("server.crt"),     data_file("client.crt"),
                 data_file("EndEntity1.crt"), data_file("EndEntity2.crt"),
                 data_file("Root_CA.crt"),    data_file("Intermediate_CA.crt"),
                 data_file("IR_protected.der"),
                 data_file("IR_unprotected.der"),
                 data_file("IP_waitingStatus_PBM.der"),
                 data_file("IR_rmprotection.der"),
                 data_file("insta.cert.pem"),
                 data_file("insta_ca.cert.pem"),
                 data_file("IR_protected_0_extraCerts.der"),
                 data_file("IR_protected_2_extraCerts.der"));

ok(run(test([@basic_cmd, "none"])));

ok(run(test([@basic_cmd, "default", srctop_file("test", "default.cnf")])));

unless ($no_fips) {
    ok(run(app(['openssl', 'fipsinstall',
                '-out', bldtop_file('providers', 'fipsmodule.cnf'),
                '-module', bldtop_file('providers', platform->dso('fips'))])),
       "fipsinstall");

    ok(run(test([@basic_cmd, "fips", srctop_file("test", "fips.cnf")])));
}