Skip to content

Commit

Permalink
Add a test case for the password prompt on garbage PKCS#12 file
Browse files Browse the repository at this point in the history
Reviewed-by: Tomas Mraz <tomas@openssl.org>
Reviewed-by: Dmitry Belyavskiy <beldmit@gmail.com>
Reviewed-by: Paul Dale <pauli@openssl.org>
(Merged from #21197)

(cherry picked from commit 1a27cc3)
  • Loading branch information
levitte authored and paulidale committed Jun 25, 2023
1 parent 56925da commit 30d5465
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 0 deletions.
36 changes: 36 additions & 0 deletions test/recipes/90-test_store_cases.t
@@ -0,0 +1,36 @@
#! /usr/bin/env perl
# Copyright 2023 The OpenSSL Project Authors. 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

# This collects specific use cases, and tests our handling

use File::Spec::Functions;
use File::Copy;
use MIME::Base64;
use OpenSSL::Test qw(:DEFAULT srctop_file srctop_dir bldtop_file bldtop_dir
data_file);
use OpenSSL::Test::Utils;

my $test_name = "test_store_cases";
setup($test_name);

plan tests => 2;

my $stderr;

# The case of the garbage PKCS#12 DER file where a passphrase was
# prompted for. That should not have happened.
$stderr = 'garbage-pkcs12.stderr.txt';
ok(!run(app(['openssl', 'storeutl', '-passin', 'pass:invalidapass',
data_file('garbage-pkcs12.p12')],
stderr => $stderr)),
"checking that storeutl fails when given a garbage pkcs12 file");
open DATA, $stderr;
@match = grep /try_pkcs12:.*?:maybe wrong password$/, <DATA>;
close DATA;
ok(scalar @match > 0 ? 0 : 1,
"checking that storeutl didn't ask for a passphrase");
1 change: 1 addition & 0 deletions test/recipes/90-test_store_cases_data/garbage-pkcs12.p12
@@ -0,0 +1 @@
0[�0 *�H�80��1 0 UUS10 Upo

0 comments on commit 30d5465

Please sign in to comment.