X-Git-Url: http://git.vpit.fr/?p=perl%2Fmodules%2Findirect.git;a=blobdiff_plain;f=t%2F30-scope.t;h=dc2870ca5c9d2fdf8bd981ddd14248ca6f1716f8;hp=7f31ebb3f9b23bb33d56287149464505a357d529;hb=84cf20f38df18db8a29e9d4676b2ffa97451c83a;hpb=cd669c3d5bb3f70d040109131da334bebed3565e diff --git a/t/30-scope.t b/t/30-scope.t index 7f31ebb..dc2870c 100644 --- a/t/30-scope.t +++ b/t/30-scope.t @@ -1,4 +1,4 @@ -#!perl -T +#!perl use strict; use warnings; @@ -6,7 +6,7 @@ use warnings; my $tests; BEGIN { $tests = 18 } -use Test::More tests => (1 + $tests + 1) + 3 + 3 + 3 + 5 + 4 + 2; +use Test::More tests => (1 + $tests + 1) + 3 + 3 + 3 + 5 + 4 + 5; BEGIN { delete $ENV{PERL_INDIRECT_PM_DISABLE} } @@ -153,6 +153,7 @@ sub expect { is $@, '', 'RT #47902'; } +# This test may not fail for the old version when ran in taint mode { my $err = eval <<' SNIP'; use indirect::TestRequired4::a0; @@ -161,6 +162,23 @@ sub expect { like $err, qr/^Can't locate object method "new" via package "X"/, 'RT #50570'; } +# This test must be in the topmost scope +BEGIN { eval 'use indirect::TestRequired5::a0' } +my $err = indirect::TestRequired5::a0::error(); +like $err, qr/^Can't locate object method "new" via package "X"/, + 'identifying requires by their eval context pointer is not enough'; + +{ + my @w; + no indirect hook => sub { push @w, indirect::msg(@_) }; + use indirect::TestRequired6; + indirect::TestRequired6::bar(); + is_deeply \@w, [ ], 'indirect syntax in sub'; + @w = (); + indirect::TestRequired6::baz(); + is_deeply \@w, [ ], 'indirect syntax in eval in sub'; +} + __DATA__ my $a = new P1;