]> git.vpit.fr Git - perl/modules/Scope-Upper.git/commitdiff
Factor similar stress level tests in t/81-stress-level.t
authorVincent Pit <vince@profvince.com>
Fri, 9 Jan 2009 18:28:54 +0000 (19:28 +0100)
committerVincent Pit <vince@profvince.com>
Fri, 9 Jan 2009 18:28:54 +0000 (19:28 +0100)
MANIFEST
t/11-reap-level.t
t/21-localize-level.t
t/31-localize_elem-level.t
t/41-localize_delete-level.t
t/81-stress-level.t [new file with mode: 0644]

index f18a425001a0b0673e7cb2d47aaabe83d61dc904..7913d057860e1dc9d90114df2aeee0302bc3b98d 100644 (file)
--- a/MANIFEST
+++ b/MANIFEST
@@ -24,6 +24,7 @@ t/34-localize_elem-magic.t
 t/40-localize_delete-target.t
 t/41-localize_delete-level.t
 t/44-localize_delete-magic.t
+t/81-stress-level.t
 t/90-boilerplate.t
 t/91-pod.t
 t/92-pod-coverage.t
index ccee71baa2d7fa90eb9097bdd1875da2a7a72c5e..8880ef3d11327f9067eab87e437cd0715707b41d 100644 (file)
@@ -42,7 +42,7 @@ DIAG
  }
 }
 
-for my $level (0 .. 4) {
+for my $level (0 .. 2) {
  for my $height ($level + 1 .. $level + 2) {
   my $tests = Scope::Upper::TestGenerator::gen($height, $level);
   for (@$tests) {
index d9cdf971812e2163c4f3225db818a7e54e828367..27effbf3bac4036052f45efaac21d0dfab6943b6 100644 (file)
@@ -40,7 +40,7 @@ DIAG
  }
 }
 
-for my $level (0 .. 4) {
+for my $level (0 .. 2) {
  for my $height ($level + 1 .. $level + 2) {
   my $tests = Scope::Upper::TestGenerator::gen($height, $level);
   for (@$tests) {
index 6f73cc49eb7aadb64042d521bd45d766d9d41893..b95acd694e9256cad9794f68acc819082ef53698 100644 (file)
@@ -25,7 +25,7 @@ local $Scope::Upper::TestGenerator::test = sub {
 
 our @a;
 
-for my $level (0 .. 4) {
+for my $level (0 .. 2) {
  for my $height ($level + 1 .. $level + 2) {
   my $tests = Scope::Upper::TestGenerator::gen($height, $level);
   for (@$tests) {
@@ -51,7 +51,7 @@ local $Scope::Upper::TestGenerator::test = sub {
 
 our %h;
 
-for my $level (0 .. 4) {
+for my $level (0 .. 2) {
  for my $height ($level + 1 .. $level + 2) {
   my $tests = Scope::Upper::TestGenerator::gen($height, $level);
   for (@$tests) {
index b7595236f61594b9d351fba841eb0b03d2d63305..799c0556ce7e2bc20ef261fe75e8b817c5fa3d0e 100644 (file)
@@ -25,7 +25,7 @@ local $Scope::Upper::TestGenerator::test = sub {
 
 our @a;
 
-for my $level (0 .. 4) {
+for my $level (0 .. 2) {
  for my $height ($level + 1 .. $level + 2) {
   my $tests = Scope::Upper::TestGenerator::gen($height, $level);
   for (@$tests) {
@@ -52,7 +52,7 @@ local $Scope::Upper::TestGenerator::test = sub {
 
 our %h;
 
-for my $level (0 .. 4) {
+for my $level (0 .. 2) {
  for my $height ($level + 1 .. $level + 2) {
   my $tests = Scope::Upper::TestGenerator::gen($height, $level);
   for (@$tests) {
diff --git a/t/81-stress-level.t b/t/81-stress-level.t
new file mode 100644 (file)
index 0000000..5dd5d43
--- /dev/null
@@ -0,0 +1,55 @@
+#!perl -T
+
+use strict;
+use warnings;
+
+use Test::More 'no_plan';
+
+use Scope::Upper qw/reap/;
+
+use lib 't/lib';
+use Scope::Upper::TestGenerator;
+
+local $Scope::Upper::TestGenerator::call = sub {
+ my ($height, $level, $i) = @_;
+ return [ "reap \\&check => $level;\n" ];
+};
+
+local $Scope::Upper::TestGenerator::test = sub {
+ my ($height, $level, $i) = @_;
+ my $j = $i < $height - $level ? 1 : 'undef';
+ return "is(\$main::y, $j, 'y h=$height, l=$level, i=$i');\n";
+};
+
+our ($x, $y, $testcase);
+
+sub check { $y = 0 unless defined $y; ++$y }
+
+{
+ no warnings 'redefine';
+ *is = sub ($$;$) {
+  my ($a, $b, $desc) = @_;
+  if (defined $testcase
+      and (defined $b) ? (not defined $a or $a != $b) : defined $a) {
+   diag <<DIAG;
+=== This testcase failed ===
+$testcase
+==== vvvvv Errors vvvvvv ===
+DIAG
+   undef $testcase;
+  }
+  Test::More::is($a, $b, $desc);
+ }
+}
+
+for my $level (0 .. 4) {
+ for my $height ($level + 1 .. $level + 2) {
+  my $tests = Scope::Upper::TestGenerator::gen($height, $level);
+  for (@$tests) {
+   $testcase = $_;
+   $x = $y = undef;
+   eval;
+   diag $@ if $@;
+  }
+ }
+}