use warnings;
my $tests;
-BEGIN { $tests = 10 }
+BEGIN { $tests = 18 }
-use Test::More tests => 1 + $tests + 1 + 2;
+use Test::More tests => 1 + $tests + 1 + 2 + 2;
-my %wrong = map { $_ => 1 } 2, 3, 5, 7, 9, 10;
+use lib 't/lib';
+
+my %wrong = map { $_ => 1 } 2, 3, 5, 7, 9, 10, 14, 15, 17, 18;
sub expect {
my ($pkg) = @_;
- return qr/^warn:Indirect\s+call\s+of\s+method\s+"new"\s+on\s+object\s+"$pkg"/;
+ return qr/^warn:Indirect\s+call\s+of\s+method\s+"new"\s+on\s+object\s+"$pkg"\s+at\s+\(eval\s+\d+\)\s+line\s+\d+/;
}
{
no indirect;
eval 'my $x = new Bar';
}
- if ($] < 5.010) {
+ if ($] < 5.009005) {
is($w, '', "eval 'no indirect; my \$x = new Bar'");
} else {
like($w, expect('Bar'), "no indirect; eval 'my \$x = new Bar'");
}
}
+{
+ local $TODO = 'Need a workaround for this' if $] < 5.010001;
+ my @w;
+ {
+ local $SIG{__WARN__} = sub { push @w, join '', @_ };
+ eval 'no indirect; use indirect::TestRequired';
+ }
+ is $@, '', 'require test didn\'t croak';
+ is_deeply \@w, [ ], 'pragma didn\'t propagate into the required file';
+}
+
__DATA__
my $a = new P1;
}
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 };
+}