use strict;
use warnings;
-use Test::More tests => 3;
+use Config;
+
+use Test::More tests => 8;
use lib 't/lib';
-use VPIT::TestHelpers;
+use VPIT::TestHelpers 'run_perl';
BEGIN { delete $ENV{PERL_INDIRECT_PM_DISABLE} }
-sub run_perl {
- my $code = shift;
-
- my ($SystemRoot, $PATH) = @ENV{qw<SystemRoot PATH>};
- local %ENV;
- $ENV{SystemRoot} = $SystemRoot if $^O eq 'MSWin32' and defined $SystemRoot;
- $ENV{PATH} = $PATH if $^O eq 'cygwin' and defined $PATH;
-
- system { $^X } $^X, '-T', map("-I$_", @INC), '-e', $code;
-}
-
-{
+SKIP: {
my $status = run_perl 'no indirect; qq{a\x{100}b} =~ /\A[\x00-\x7f]*\z/;';
+ skip RUN_PERL_FAILED() => 1 unless defined $status;
is $status, 0, 'RT #47866';
}
-SKIP:
-{
+SKIP: {
skip 'Fixed in core only since 5.12' => 1 unless "$]" >= 5.012;
+
my $status = run_perl 'no indirect hook => sub { exit 2 }; new X';
+ skip RUN_PERL_FAILED() => 1 unless defined $status;
is $status, 2 << 8, 'no semicolon at the end of -e';
}
-SKIP:
-{
+SKIP: {
load_or_skip('Devel::CallParser', undef, undef, 1);
+
my $status = run_perl "use Devel::CallParser (); no indirect; sub ok { } ok 1";
+ skip RUN_PERL_FAILED() => 1 unless defined $status;
is $status, 0, 'indirect is not getting upset by Devel::CallParser';
}
+
+SKIP: {
+ my $has_package_empty = do {
+ local $@;
+ eval 'no warnings "deprecated"; package; 1'
+ };
+ skip 'Empty package only available on perl 5.8.x and below' => 1
+ unless $has_package_empty;
+
+ my $status = run_perl 'no indirect hook => sub { }; exit 0; package; new X;';
+ skip RUN_PERL_FAILED() => 1 unless defined $status;
+ is $status, 0, 'indirect does not croak while package empty is in use';
+}
+
+my $fork_status;
+if ($Config::Config{d_fork} or $Config::Config{d_pseudofork}) {
+ $fork_status = run_perl 'my $pid = fork; exit 1 unless defined $pid; if ($pid) { waitpid $pid, 0; my $status = $?; exit(($status >> 8) || $status) } else { exit 0 }';
+}
+
+SKIP: {
+ my $tests = 2;
+ skip 'fork() or pseudo-forks are required to check END blocks in subprocesses'
+ => $tests unless defined $fork_status;
+ skip "Could not even fork a simple process (sample returned $fork_status)"
+ => $tests unless $fork_status == 0;
+
+ my $status = run_perl 'require indirect; END { eval q[1] } my $pid = fork; exit 0 unless defined $pid; if ($pid) { waitpid $pid, 0; my $status = $?; exit(($status >> 8) || $status) } else { exit 0 }';
+ skip RUN_PERL_FAILED() => $tests unless defined $status;
+ is $status, 0, 'indirect and global END blocks executed at the end of a forked process (RT #99083)';
+
+ $status = run_perl 'require indirect; my $pid = fork; exit 0 unless defined $pid; if ($pid) { waitpid $pid, 0; my $status = $?; exit(($status >> 8) || $status) } else { eval q[END { eval q(1) }]; exit 0 }';
+ skip RUN_PERL_FAILED() => ($tests - 1) unless defined $status;
+ is $status, 0, 'indirect and local END blocks executed at the end of a forked process';
+}
+
+SKIP: {
+ my $status;
+ for my $run (1 .. 10) {
+ $status = run_perl_file 't/testcases/rt115392.pl';
+ skip RUN_PERL_FAILED() => 1 unless defined $status;
+ last if $status;
+ }
+ is $status, 0, 'RT #115392';
+}
+
+SKIP: {
+ my $status = run_perl_file 't/testcases/babycart_in_heredoc.pl';
+ skip RUN_PERL_FAILED() => 1 unless defined $status;
+ is $status, 0, 'babycart in heredoc';
+}