2016-04-22 19:21:51 +08:00
|
|
|
#! /usr/bin/env perl
|
2023-09-07 16:59:15 +08:00
|
|
|
# Copyright 2015-2023 The OpenSSL Project Authors. All Rights Reserved.
|
2016-04-22 19:21:51 +08:00
|
|
|
#
|
2018-12-06 20:05:25 +08:00
|
|
|
# Licensed under the Apache License 2.0 (the "License"). You may not use
|
2016-04-22 19:21:51 +08:00
|
|
|
# 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
|
|
|
|
|
2015-04-18 02:07:13 +08:00
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
|
|
|
|
|
|
|
use File::Spec::Functions qw/catfile/;
|
|
|
|
use File::Copy;
|
|
|
|
use File::Compare qw/compare_text/;
|
|
|
|
use File::Basename;
|
2020-04-09 10:47:46 +08:00
|
|
|
use OpenSSL::Test qw/:DEFAULT srctop_file bldtop_dir/;
|
2020-12-02 20:45:47 +08:00
|
|
|
use OpenSSL::Test::Utils;
|
2015-04-18 02:07:13 +08:00
|
|
|
|
|
|
|
setup("test_enc");
|
2020-12-12 13:23:20 +08:00
|
|
|
plan skip_all => "Deprecated functions are disabled in this OpenSSL build"
|
|
|
|
if disabled("deprecated");
|
2015-04-18 02:07:13 +08:00
|
|
|
|
|
|
|
# We do it this way, because setup() may have moved us around,
|
|
|
|
# so the directory portion of $0 might not be correct any more.
|
|
|
|
# However, the name hasn't changed.
|
2016-01-30 08:05:33 +08:00
|
|
|
my $testsrc = srctop_file("test","recipes",basename($0));
|
2015-04-18 02:07:13 +08:00
|
|
|
|
|
|
|
my $test = catfile(".", "p");
|
|
|
|
|
|
|
|
my $cmd = "openssl";
|
2020-04-09 10:47:46 +08:00
|
|
|
my $provpath = bldtop_dir("providers");
|
2020-12-02 20:45:47 +08:00
|
|
|
my @prov = ("-provider-path", $provpath, "-provider", "default");
|
|
|
|
push @prov, ("-provider", "legacy") unless disabled("legacy");
|
2017-03-21 18:26:28 +08:00
|
|
|
my $ciphersstatus = undef;
|
2015-04-18 02:07:13 +08:00
|
|
|
my @ciphers =
|
2015-10-13 04:24:27 +08:00
|
|
|
map { s/^\s+//; s/\s+$//; split /\s+/ }
|
2017-03-21 18:26:28 +08:00
|
|
|
run(app([$cmd, "list", "-cipher-commands"]),
|
|
|
|
capture => 1, statusvar => \$ciphersstatus);
|
2020-12-02 20:45:47 +08:00
|
|
|
@ciphers = grep {!/^(bf|cast|des$|des-cbc|des-cfb|des-ecb|des-ofb|desx|idea
|
|
|
|
|rc2|rc4|seed)/x} @ciphers
|
|
|
|
if disabled("legacy");
|
2015-04-18 02:07:13 +08:00
|
|
|
|
2023-08-31 15:51:46 +08:00
|
|
|
plan tests => 5 + (scalar @ciphers)*2;
|
2015-04-18 02:07:13 +08:00
|
|
|
|
|
|
|
SKIP: {
|
2017-03-21 18:26:28 +08:00
|
|
|
skip "Problems getting ciphers...", 1 + scalar(@ciphers)
|
|
|
|
unless ok($ciphersstatus, "Running 'openssl list -cipher-commands'");
|
|
|
|
unless (ok(copy($testsrc, $test), "Copying $testsrc to $test")) {
|
|
|
|
diag($!);
|
|
|
|
skip "Not initialized, skipping...", scalar(@ciphers);
|
|
|
|
}
|
2015-04-18 02:07:13 +08:00
|
|
|
|
|
|
|
foreach my $c (@ciphers) {
|
2021-06-18 15:46:40 +08:00
|
|
|
my %variant = ("$c" => [],
|
|
|
|
"$c base64" => [ "-a" ]);
|
2015-04-18 02:07:13 +08:00
|
|
|
|
2021-06-18 15:46:40 +08:00
|
|
|
foreach my $t (sort keys %variant) {
|
|
|
|
my $cipherfile = "$test.$c.cipher";
|
|
|
|
my $clearfile = "$test.$c.clear";
|
|
|
|
my @e = ( "$c", "-bufsize", "113", @{$variant{$t}}, "-e", "-k", "test" );
|
|
|
|
my @d = ( "$c", "-bufsize", "157", @{$variant{$t}}, "-d", "-k", "test" );
|
|
|
|
if ($c eq "cat") {
|
|
|
|
$cipherfile = "$test.cipher";
|
|
|
|
$clearfile = "$test.clear";
|
|
|
|
@e = ( "enc", @{$variant{$t}}, "-e" );
|
|
|
|
@d = ( "enc", @{$variant{$t}}, "-d" );
|
|
|
|
}
|
2015-04-18 02:07:13 +08:00
|
|
|
|
2021-06-18 15:46:40 +08:00
|
|
|
ok(run(app([$cmd, @e, @prov, "-in", $test, "-out", $cipherfile]))
|
|
|
|
&& run(app([$cmd, @d, @prov, "-in", $cipherfile, "-out", $clearfile]))
|
|
|
|
&& compare_text($test,$clearfile) == 0, $t);
|
|
|
|
}
|
2015-04-18 02:07:13 +08:00
|
|
|
}
|
2023-08-31 15:51:46 +08:00
|
|
|
ok(run(app([$cmd, "enc", "-in", $test, "-aes256", "-pbkdf2", "-out",
|
|
|
|
"salted_default.cipher", "-pass", "pass:password"]))
|
|
|
|
&& run(app([$cmd, "enc", "-d", "-in", "salted_default.cipher", "-aes256", "-pbkdf2",
|
|
|
|
"-saltlen", "8", "-out", "salted_default.clear", "-pass", "pass:password"]))
|
|
|
|
&& compare_text($test,"salted_default.clear") == 0,
|
|
|
|
"Check that the default salt length of 8 bytes is used for PKDF2");
|
|
|
|
|
|
|
|
ok(!run(app([$cmd, "enc", "-d", "-in", "salted_default.cipher", "-aes256", "-pbkdf2",
|
|
|
|
"-saltlen", "16", "-out", "salted_fail.clear", "-pass", "pass:password"])),
|
|
|
|
"Check the decrypt fails if the saltlen is incorrect");
|
|
|
|
|
|
|
|
ok(run(app([$cmd, "enc", "-in", $test, "-aes256", "-pbkdf2", "-saltlen", "16",
|
|
|
|
"-out", "salted.cipher", "-pass", "pass:password"]))
|
|
|
|
&& run(app([$cmd, "enc", "-d", "-in", "salted.cipher", "-aes256", "-pbkdf2",
|
|
|
|
"-saltlen", "16", "-out", "salted.clear", "-pass", "pass:password"]))
|
|
|
|
&& compare_text($test,"salted.clear") == 0,
|
|
|
|
"Check that we can still use a salt length of 16 bytes for PKDF2");
|
|
|
|
|
2015-04-18 02:07:13 +08:00
|
|
|
}
|