summaryrefslogtreecommitdiff
path: root/test/recipes/90-test_gost.t
blob: c7bbb4edd8d4214b355fa4620234e48d6a5755ec (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#! /usr/bin/env perl
# Copyright 2018 The OpenSSL Project Authors. All Rights Reserved.
#
# Licensed under the OpenSSL license (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 OpenSSL::Test::Utils;
use OpenSSL::Test qw/:DEFAULT srctop_file/;

setup("test_gost");

# The GOST ciphers are dynamically loaded via the GOST engine, so we must be
# able to support that. The engine also uses DSA and CMS symbols, so we skip
# this test on no-dsa or no-cms.
plan skip_all => "GOST support is disabled in this OpenSSL build"
    if disabled("gost") || disabled("engine") || disabled("dynamic-engine")
       || disabled("dsa") || disabled("cms");

plan skip_all => "TLSv1.3 or TLSv1.2 are disabled in this OpenSSL build"
    if disabled("tls1_3") || disabled("tls1_2");

plan skip_all => "No test GOST engine found"
    if !$ENV{OPENSSL_GOST_ENGINE_SO};

plan tests => 1;

$ENV{OPENSSL_CONF} = srctop_file("test", "recipes", "90-test_gost_data",
                                 "gost.conf");

ok(run(test(["gosttest",
             srctop_file("test", "recipes", "90-test_gost_data",
                         "server-cert2001.pem"),
             srctop_file("test", "recipes", "90-test_gost_data",
                         "server-key2001.pem"),
             srctop_file("test", "recipes", "90-test_gost_data",
                         "server-cert2012.pem"),
             srctop_file("test", "recipes", "90-test_gost_data",
                         "server-key2012.pem")])),
             "running gosttest");