提交 34a6a9b1 编写于 作者: R Richard Levitte

OpenSSL::Test: add a statusvar option for run with capture => 1

When using run() with capture => 1, there was no way to find out if
the command was successful or not.  This change adds a statusvar
option, that must refer to a scalar variable, for example:

    my $status = undef;
    my @line = run(["whatever"], capture => 1, statusvar => \$status);

$status will be 1 if the command "whatever" was successful, 0
otherwise.
Reviewed-by: NRich Salz <rsalz@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/3004)
上级 b6ef12c4
...@@ -403,6 +403,12 @@ return the resulting output as an array of lines. If false or not given, ...@@ -403,6 +403,12 @@ return the resulting output as an array of lines. If false or not given,
the command will be executed with C<system()>, and C<run> will return 1 if the command will be executed with C<system()>, and C<run> will return 1 if
the command was successful or 0 if it wasn't. the command was successful or 0 if it wasn't.
=item B<statusvar =E<gt> VARREF>
If used, B<VARREF> must be a reference to a scalar variable. It will be
assigned a boolean indicating if the command succeeded or not. This is
particularly useful together with B<capture>.
=back =back
For further discussion on what is considered a successful command or not, see For further discussion on what is considered a successful command or not, see
...@@ -427,6 +433,9 @@ sub run { ...@@ -427,6 +433,9 @@ sub run {
my $r = 0; my $r = 0;
my $e = 0; my $e = 0;
die "OpenSSL::Test::run(): statusvar value not a scalar reference"
if $opts{statusvar} && ref($opts{statusvar}) ne "SCALAR";
# In non-verbose, we want to shut up the command interpreter, in case # In non-verbose, we want to shut up the command interpreter, in case
# it has something to complain about. On VMS, it might complain both # it has something to complain about. On VMS, it might complain both
# on stdout and stderr # on stdout and stderr
...@@ -445,11 +454,13 @@ sub run { ...@@ -445,11 +454,13 @@ sub run {
# to make it easier to compare with a manual run of the command. # to make it easier to compare with a manual run of the command.
if ($opts{capture}) { if ($opts{capture}) {
@r = `$prefix$cmd`; @r = `$prefix$cmd`;
$e = ($? & 0x7f) ? ($? & 0x7f)|0x80 : ($? >> 8);
} else { } else {
system("$prefix$cmd"); system("$prefix$cmd");
$e = ($? & 0x7f) ? ($? & 0x7f)|0x80 : ($? >> 8); }
$r = $hooks{exit_checker}->($e); $e = ($? & 0x7f) ? ($? & 0x7f)|0x80 : ($? >> 8);
$r = $hooks{exit_checker}->($e);
if ($opts{statusvar}) {
${$opts{statusvar}} = $r;
} }
if ($ENV{HARNESS_ACTIVE} && !$ENV{HARNESS_VERBOSE}) { if ($ENV{HARNESS_ACTIVE} && !$ENV{HARNESS_VERBOSE}) {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册