]> git.vpit.fr Git - perl/modules/Scope-Upper.git/blob - t/12-reap-block.t
Doc update
[perl/modules/Scope-Upper.git] / t / 12-reap-block.t
1 #!perl -T
2
3 use strict;
4 use warnings;
5
6 use Test::More 'no_plan'; 
7
8 use Scope::Upper qw/reap UP HERE/;
9
10 use lib 't/lib';
11 use Scope::Upper::TestGenerator;
12
13 local $Scope::Upper::TestGenerator::call = sub {
14  my ($height, $level, $i) = @_;
15  $level = $level ? 'UP ' x $level : 'HERE';
16  return [ "reap \\&check => $level;\n" ];
17 };
18
19 local $Scope::Upper::TestGenerator::test = sub {
20  my ($height, $level, $i, $x) = @_;
21  my $j = $i < $height - $level ? 0 : (defined $x ? $x : 'undef');
22  return "is(\$x, $j, 'x h=$height, l=$level, i=$i');\n";
23 };
24
25 local $Scope::Upper::TestGenerator::local = sub {
26  my ($height, $level, $i, $x) = @_;
27  return $i == $height - $level ? "\$x = $x;\n" : "local \$x = $x;\n";
28 };
29
30 local $Scope::Upper::TestGenerator::testlocal = sub { '' };
31
32 local $Scope::Upper::TestGenerator::allblocks = 1;
33
34 our ($x, $testcase);
35
36 sub check { $x = (defined $x) ? ($x ? 0 : $x . 'x') : 0 }
37
38 {
39  no warnings 'redefine';
40  *is = sub ($$;$) {
41   my ($a, $b, $desc) = @_;
42   if (defined $testcase
43       and (defined $b) ? (not defined $a or $a != $b) : defined $a) {
44    diag <<DIAG;
45 === This testcase failed ===
46 $testcase
47 ==== vvvvv Errors vvvvvv ===
48 DIAG
49    undef $testcase;
50   }
51   Test::More::is($a, $b, $desc);
52  }
53 }
54
55 for my $level (0 .. 1) {
56  my $height = $level + 1;
57  my $tests = Scope::Upper::TestGenerator::gen($height, $level);
58  for (@$tests) {
59   $testcase = $_;
60   $x = undef;
61   eval;
62   diag $@ if $@;
63  }
64 }