mirror of
https://github.com/openssl/openssl.git
synced 2025-01-12 13:36:28 +08:00
f2130201f1
If the legacy provider isn't available then we shouldn't attempt to load or use it. Reviewed-by: Richard Levitte <levitte@openssl.org> (Merged from https://github.com/openssl/openssl/pull/13595)
67 lines
2.2 KiB
Perl
67 lines
2.2 KiB
Perl
#! /usr/bin/env perl
|
|
# Copyright 2017-2020 The OpenSSL Project Authors. All Rights Reserved.
|
|
# Copyright (c) 2017, Oracle and/or its affiliates. All rights reserved.
|
|
#
|
|
# 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 warnings;
|
|
|
|
use File::Spec::Functions qw/catfile/;
|
|
use File::Copy;
|
|
use File::Compare qw/compare_text/;
|
|
use File::Basename;
|
|
use OpenSSL::Test qw/:DEFAULT srctop_file bldtop_dir/;
|
|
use OpenSSL::Test::Utils;
|
|
|
|
|
|
setup("test_evp_more");
|
|
|
|
my $testsrc = srctop_file("test", "recipes", basename($0));
|
|
|
|
my $cipherlist = undef;
|
|
my $plaintext = catfile(".", "testdatafile");
|
|
my $fail = "";
|
|
my $cmd = "openssl";
|
|
my $provpath = bldtop_dir("providers");
|
|
my @prov = ("-provider-path", $provpath, "-provider", "default");
|
|
push @prov, ("-provider", "legacy") unless disabled("legacy");
|
|
|
|
my $ciphersstatus = undef;
|
|
my @ciphers =
|
|
grep(! /wrap|^$|^[^-]/,
|
|
(map { split /\s+/ }
|
|
run(app([$cmd, "enc", "-list"]),
|
|
capture => 1, statusvar => \$ciphersstatus)));
|
|
@ciphers = grep {!/^-(bf|blowfish|cast|des$|des-cbc|des-cfb|des-ecb|des-ofb
|
|
|desx|idea|rc2|rc4|seed)/x} @ciphers
|
|
if disabled("legacy");
|
|
|
|
plan tests => 2 + scalar @ciphers;
|
|
|
|
SKIP: {
|
|
skip "Problems getting ciphers...", 1 + scalar(@ciphers)
|
|
unless ok($ciphersstatus, "Running 'openssl enc -list'");
|
|
unless (ok(copy($testsrc, $plaintext), "Copying $testsrc to $plaintext")) {
|
|
diag($!);
|
|
skip "Not initialized, skipping...", scalar(@ciphers);
|
|
}
|
|
|
|
foreach my $cipher (@ciphers) {
|
|
my $ciphername = substr $cipher, 1;
|
|
my $cipherfile = "$plaintext.$ciphername.cipher";
|
|
my $clearfile = "$plaintext.$ciphername.clear";
|
|
my @common = ( $cmd, "enc", "$cipher", "-k", "test" );
|
|
|
|
ok(run(app([@common, @prov, "-e", "-in", $plaintext, "-out", $cipherfile]))
|
|
&& compare_text($plaintext, $cipherfile) != 0
|
|
&& run(app([@common, @prov, "-d", "-in", $cipherfile, "-out", $clearfile]))
|
|
&& compare_text($plaintext, $clearfile) == 0
|
|
, $ciphername);
|
|
}
|
|
}
|