X-Git-Url: http://git.vpit.fr/?p=perl%2Fmodules%2Findirect.git;a=blobdiff_plain;f=t%2F30-scope.t;h=2b937f78fc63882e8df604ecef21626e1a0569d6;hp=f2a785f38b2d1830c6c5eca061100ade95e919c5;hb=refs%2Ftags%2Frt47902;hpb=7ded1e91a0a0ddc3e709cda9573fe0e53a32e092 diff --git a/t/30-scope.t b/t/30-scope.t index f2a785f..2b937f7 100644 --- a/t/30-scope.t +++ b/t/30-scope.t @@ -4,36 +4,114 @@ use strict; use warnings; my $tests; -BEGIN { $tests = 8 } +BEGIN { $tests = 18 } -use Test::More tests => $tests + 1; +use Test::More tests => 1 + $tests + 1 + 2 + 3 + 5 + 1; -my %wrong = map { $_ => 1 } 2, 3, 5, 7; +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\s+\d+\)'; + return qr/^warn:Indirect\s+call\s+of\s+method\s+"new"\s+on\s+object\s+"$pkg"\s+at\s+$file\s+line\s+\d+/; +} { my $code = do { local $/; }; - my @warns; + my (%res, $num, @left); { - local $SIG{__WARN__} = sub { push @warns, join '', 'warn:', @_ }; + local $SIG{__WARN__} = sub { + ++$num; + my $w = join '', 'warn:', @_; + if ($w =~ /"P(\d+)"/ and not exists $res{$1}) { + $res{$1} = $w; + } else { + push @left, "[$num] $w"; + } + }; eval "die qq{ok\\n}; $code"; + is($@, "ok\n", 'DATA compiled fine'); } - my $left = 0; - my %res = map { - if (/"P(\d+)"/) { - $1 => $_ - } else { - ++$left; () - } - } @warns; for (1 .. $tests) { my $w = $res{$_}; if ($wrong{$_}) { - like($w, qr/^warn:Indirect\s+call\s+of\s+method\s+"new"\s+on\s+object\s+"P$_"/, "$_ should warn"); + like($w, expect("P$_"), "$_ should warn"); } else { is($w, undef, "$_ shouldn't warn"); } } - is($left, 0, 'nothing left'); + is(@left, 0, 'nothing left'); + diag "Extraneous warnings:\n", @left if @left; +} + +{ + my $w = ''; + local $SIG{__WARN__} = sub { + $w = 'more than 2 warnings' if $w; + $w = join '', 'warn:', @_ + }; + { + eval 'no indirect; my $x = new Foo'; + like($w, expect('Foo'), "eval 'no indirect; my \$x = new Foo'"); + } + $w = ''; + { + { + no indirect; + eval 'my $x = new Bar'; + } + if ($] < 5.009005) { + is($w, '', "eval 'no indirect; my \$x = new Bar'"); + } else { + like($w, expect('Bar'), "no indirect; eval 'my \$x = new Bar'"); + } + } +} + +{ + my @w; + { + local $SIG{__WARN__} = sub { push @w, join '', 'warn:', @_ }; + eval "die qq{ok\\n}; no indirect; use indirect::TestRequired1; my \$x = new Foo;"; + } + is $@, "ok\n", 'first require test doesn\'t croak prematurely'; + my $w = shift @w; + like $w, expect('Foo'), 'first require test catch errors in current scope'; + is_deeply \@w, [ ], 'first require test doesn\'t propagate into the required file'; +} + +{ + my @w; + { + local $SIG{__WARN__} = sub { push @w, join '', 'warn:', @_ }; + eval "die qq{ok\\n}; no indirect; use indirect::TestRequired2; my \$x = new Bar;"; + } + @w = grep !/^warn:Attempt\s+to\s+free\s+unreferenced/, @w if $] <= 5.008003; + is $@, "ok\n", 'second require test doesn\'t croak prematurely'; + 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; + $w = shift @w; + like $w, expect('Blech'), 'second require test caught error for Blech'; + } + $w = shift @w; + like $w, expect('Bar'), 'second require test caught error for Bar'; + is_deeply \@w, [ ], 'second require test doesn\'t have more errors'; +} + +{ + eval <<' SNIP'; + return; + no indirect ':fatal'; + use indirect::Test1::il1 (); + use indirect::Test1::il2 (); + SNIP + is $@, '', 'RT #47902'; } __DATA__ @@ -61,3 +139,30 @@ my $g = new P7; use indirect; my $h = new P8; + +{ + no indirect; + eval { my $i = new P9 }; +} + +eval { no indirect; my $j = new P10 }; + +{ + use indirect; + new P11 do { use indirect; new P12 }; +} + +{ + use indirect; + new P13 do { no indirect; new P14 }; +} + +{ + no indirect; + new P15 do { use indirect; new P16 }; +} + +{ + no indirect; + new P17 do { no indirect; new P18 }; +}