From b8fcd4f079121179f1511fbed5150209c798ce4d Mon Sep 17 00:00:00 2001 From: Richard Levitte Date: Tue, 29 Mar 2016 19:36:55 +0200 Subject: Add the option 'interpreter_args' to perlapps() and perltest() MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit The intention with that option is to allow extra flags to the perl interpreter itself. Reviewed-by: Emilia Käsper --- test/testlib/OpenSSL/Test.pm | 24 +++++++++++++++++++++--- 1 file changed, 21 insertions(+), 3 deletions(-) (limited to 'test') diff --git a/test/testlib/OpenSSL/Test.pm b/test/testlib/OpenSSL/Test.pm index 2b0c0506c8..36bb571dfc 100644 --- a/test/testlib/OpenSSL/Test.pm +++ b/test/testlib/OpenSSL/Test.pm @@ -244,7 +244,23 @@ string PATH, I, if the value is C, C or similar. =item B Both these functions function the same way as B and B, except -that they expect the command to be a perl script. +that they expect the command to be a perl script. Also, they support one +more option: + +=over 4 + +=item B ARRAYref> + +The array reference is a set of arguments for perl rather than the script. +Take care so that none of them can be seen as a script! Flags and their +eventual arguments only! + +=back + +An example: + + ok(run(perlapp(["foo.pl", "arg1"], + interpreter_args => [ "-I", srctop_dir("test") ]))); =back @@ -801,6 +817,7 @@ sub __build_cmd { my $path_builder = shift; # Make a copy to not destroy the caller's array my @cmdarray = ( @{$_[0]} ); shift; + my %opts = @_; # We do a little dance, as $path_builder might return a list of # more than one. If so, only the first is to be considered a @@ -820,8 +837,9 @@ sub __build_cmd { } } my @args = (@prog, @cmdarray); - - my %opts = @_; + if (defined($opts{interpreter_args})) { + unshift @args, @{$opts{interpreter_args}}; + } return () if !$cmd; -- cgit v1.2.3