]> git.vpit.fr Git - perl/modules/indirect.git/blobdiff - t/22-bad-mixed.t
Remove some dead code in indirect_ck_method
[perl/modules/indirect.git] / t / 22-bad-mixed.t
index 3a01f463bbe19124219dac69a05ba0f09e37ad39..cff75658737a885ebd4a3da0bd9c895e01942bcd 100644 (file)
@@ -9,35 +9,68 @@ package main;
 use strict;
 use warnings;
 
-use Test::More tests => 3 * 4;
+use Test::More tests => 3 * 9;
+
+BEGIN { delete $ENV{PERL_INDIRECT_PM_DISABLE} }
 
 sub meh;
 
+my @warns;
+
+sub try {
+ my ($code) = @_;
+
+ @warns = ();
+ {
+  local $SIG{__WARN__} = sub { push @warns, @_ };
+  eval $code;
+ }
+}
+
 {
- local $/ = "####\n";
+ local $/ = "####";
  while (<DATA>) {
   chomp;
   s/\s*$//;
+  s/(.*?)$//m;
+  my ($skip, $prefix) = split /#+/, $1;
+  $skip   = 0  unless defined $skip;
+  $prefix = '' unless defined $prefix;
+  s/\s*//;
 
-  local $SIG{__WARN__} = sub { die 'warn:' . join(' ', @_) };
+SKIP:
+  {
+   skip "$_: $skip" => 9 if eval $skip;
 
-  eval "die qq{ok\\n}; use indirect; $_";
-  is($@, "ok\n", "use indirect: $_");
+   {
+    try "return; $prefix; use indirect; $_";
+    is $@,     '', "use indirect: $_";
+    is @warns, 0,  'correct number of reports';
 
-  eval "die qq{ok\n}; no indirect; $_";
-  is($@, "ok\n", "no indirect: $_");
+    try "return; $prefix; no indirect; $_";
+    is $@,     '', "no indirect: $_";
+    is @warns, 0,  'correct number of reports';
+   }
 
-  s/Hlagh/Dongs/g;
+   {
+    local $_ = $_;
+    s/Hlagh/Dongs/g;
 
-  eval "die qq{ok\\n}; use indirect; $_";
-  is($@, "ok\n", "use indirect, defined: $_");
+    try "return; $prefix; use indirect; $_";
+    is $@,     '', "use indirect, defined: $_";
+    is @warns, 0,  'correct number of reports';
 
-  eval "die qq{the code compiled but it shouldn't have\n}; no indirect; $_";
-  like($@, qr/^warn:Indirect\s+call\s+of\s+method\s+"meh"\s+on\s+object\s+"Dongs"/, "no indirect, defined: $_");
+    try "return; $prefix; no indirect; $_";
+    is $@,          '', "use indirect, defined: $_";
+    is @warns,      1,  'correct number of reports';
+    like $warns[0], qr/^Indirect call of method "meh" on object "Dongs" at \(eval \d+\) line \d+/, 'report 0 is correct';
+   }
+  }
  }
 }
 
 __DATA__
+
 meh Hlagh->new;
 ####
 meh Hlagh->new();