X-Git-Url: http://git.vpit.fr/?p=perl%2Fmodules%2Findirect.git;a=blobdiff_plain;f=t%2F30-scope.t;h=a69b9799ce1c54362265a54471bdaf167285510b;hp=e83819de0b6c6b8ab47a89e179e226cf0ae99320;hb=refs%2Ftags%2Frt83659;hpb=f23fcd5b540fd0b7a075ba6c71d7e6d3245a7dd5 diff --git a/t/30-scope.t b/t/30-scope.t index e83819d..a69b979 100644 --- a/t/30-scope.t +++ b/t/30-scope.t @@ -6,7 +6,7 @@ use warnings; my $tests; BEGIN { $tests = 18 } -use Test::More tests => (1 + $tests + 1) + 3 + 3 + 3 + 5 + 4 + 5; +use Test::More tests => (1 + $tests + 1) + 2 + 3 + 3 + 3 + 5 + 4 + 5 + 4; BEGIN { delete $ENV{PERL_INDIRECT_PM_DISABLE} } @@ -15,9 +15,11 @@ use lib 't/lib'; my %wrong = map { $_ => 1 } 2, 3, 5, 7, 9, 10, 14, 15, 17, 18; sub expect { - my ($pkg, $file) = @_; - $file = $file ? quotemeta $file : '\(eval \d+\)'; - qr/^warn:Indirect call of method "new" on object "$pkg" at $file line \d+/; + my ($obj, $file, $prefix) = @_; + $obj = quotemeta $obj; + $file = $file ? quotemeta $file : '\(eval \d+\)'; + $prefix = defined $prefix ? quotemeta $prefix : 'warn:'; + qr/^${prefix}Indirect call of method "new" on object "$obj" at $file line \d+/; } { @@ -73,7 +75,7 @@ sub expect { } } is $@, '', "no indirect; eval 'my \$x = new Bar'"; - if ($] < 5.009005) { + if ("$]" < 5.009005) { is @w, 0, 'no warnings caught'; pass 'placeholder'; } else { @@ -83,6 +85,20 @@ sub expect { } } +SKIP: { + skip 'The pragma doesn\'t propagte into eval STRING before perl 5.10' => 2 + if "$]" < 5.009005; + my @w; + my $test = sub { eval 'return; new XYZ' }; + { + local $SIG{__WARN__} = sub { push @w, join '', 'warn:', @_ }; + eval 'return; no indirect; BEGIN { $test->() }'; + } + is $@, '', 'eval test doesn\'t croak prematurely'; + is @w, 0, 'eval did not throw a warning'; + diag join "\n", 'All warnings:', @w if @w; +} + { my @w; { @@ -102,13 +118,13 @@ sub expect { eval "return; no indirect; use indirect::TestRequired2; my \$x = new Bar;"; } is $@, '', 'second require test doesn\'t croak prematurely'; - @w = grep !/^warn:Attempt\s+to\s+free\s+unreferenced/, @w if $] <= 5.008003; + @w = grep !/^warn:Attempt\s+to\s+free\s+unreferenced/, @w if "$]" <= 5.008003; my $w = shift @w; like $w, expect('Baz', 't/lib/indirect/TestRequired2.pm'), 'second require test caught error for Baz'; SKIP: { skip 'The pragma doesn\'t propagte into eval STRING before perl 5.10' => 1 - if $] < 5.009005; + if "$]" < 5.009005; $w = shift @w; like $w, expect('Blech'), 'second require test caught error for Blech'; } @@ -132,7 +148,7 @@ sub expect { new indirect::TestRequired3Z; } TESTREQUIRED3 - @w = grep !/^warn:Attempt\s+to\s+free\s+unreferenced/, @w if $] <= 5.008003; + @w = grep !/^warn:Attempt\s+to\s+free\s+unreferenced/, @w if "$]" <= 5.008003; is $@, '', "pragma leak when reusing callback test doesn't croak prematurely"; is_deeply \@w, [ ], @@ -179,6 +195,31 @@ like $err, qr/^Can't locate object method "new" via package "X"/, is_deeply \@w, [ ], 'indirect syntax in eval in sub'; } +{ + local $@; + eval { require indirect::Test2 }; + is $@, '', 'direct call in string is not fooled by newlines'; +} + +{ + local $@; + eval { require indirect::Test3 }; + like $@, expect('$x', 't/lib/indirect/Test3.pm', ''), + 'indirect call in string is not fooled by newlines'; +} + +{ + local $@; + eval { require indirect::Test4 }; + is $@, '', 'direct call in string is not fooled by more newlines'; +} + +{ + local $@; + eval { require indirect::Test5 }; + is $@, '', 'direct call in sort in string is not fooled by newlines'; +} + __DATA__ my $a = new P1;