]> git.vpit.fr Git - perl/modules/Variable-Magic.git/blobdiff - t/31-array.t
Importing Variable-Magic-0.13.tar.gz
[perl/modules/Variable-Magic.git] / t / 31-array.t
index a7496a9a338c4d69b6f59e9d470d24dbcb426d7c..9f49f2e2863b670b45fa64d205b964503038501c 100644 (file)
@@ -5,14 +5,15 @@ use warnings;
 
 use Test::More tests => 21;
 
-use Variable::Magic qw/wizard cast dispell/;
+use Variable::Magic qw/wizard cast dispell VMG_COMPAT_ARRAY_PUSH_NOLEN VMG_COMPAT_ARRAY_UNDEF_CLEAR/;
 
 my @c = (0) x 12;
 my @x = (0) x 12;
 
 sub check {
- for (0 .. 11) { return 0 unless $c[$_] == $x[$_]; }
- return 1;
+ is join(':', map { (defined) ? $_ : 'u' } @c[0 .. 11]),
+    join(':', map { (defined) ? $_ : 'u' } @x[0 .. 11]),
+    $_[0];
 }
 
 my $wiz = wizard get   => sub { ++$c[0] },
@@ -27,84 +28,84 @@ my $wiz = wizard get   => sub { ++$c[0] },
                  store => sub { ++$c[9] },
                  'exists' => sub { ++$c[10] },
                  'delete' => sub { ++$c[11] };
-ok(check(), 'array : create wizard');
+check('array : create wizard');
 
 my @n = map { int rand 1000 } 1 .. 5;
 my @a = @n;
 
 cast @a, $wiz;
-ok(check(), 'array : cast');
+check('array : cast');
 
 my $b = $a[2];
-ok(check(), 'array : assign element to');
+check('array : assign element to');
 
 my @b = @a;
 ++$x[2];
-ok(check(), 'array : assign to');
+check('array : assign to');
 
 $b = "X@{a}Y";
 ++$x[2];
-ok(check(), 'array : interpolate');
+check('array : interpolate');
 
 $b = \@a;
-ok(check(), 'array : reference');
+check('array : reference');
 
 @b = @a[2 .. 4];
-ok(check(), 'array : slice');
+check('array : slice');
 
 @a = qw/a b d/;
 $x[1] += 3; ++$x[3];
-ok(check(), 'array : assign');
+check('array : assign');
 
 $a[2] = 'c';
-ok(check(), 'array : assign old element');
+check('array : assign old element');
 
 $a[3] = 'd';
 ++$x[1];
-ok(check(), 'array : assign new element');
+check('array : assign new element');
 
 push @a, 'x';
-++$x[1]; ++$x[2] unless $^V && $^V gt 5.9.2; # since 5.9.3
-ok(check(), 'array : push');
+++$x[1]; ++$x[2] unless VMG_COMPAT_ARRAY_PUSH_NOLEN;
+check('array : push');
 
 pop @a;
 ++$x[1]; ++$x[2];
-ok(check(), 'array : pop');
+check('array : pop');
 
 unshift @a, 'x';
 ++$x[1]; ++$x[2];
-ok(check(), 'array : unshift');
+check('array : unshift');
 
 shift @a;
 ++$x[1]; ++$x[2];
-ok(check(), 'array : shift');
+check('array : shift');
 
 $b = @a;
 ++$x[2];
-ok(check(), 'array : length');
+check('array : length');
 
 @a = map ord, @a; 
 $x[1] += 4; ++$x[2]; ++$x[3];
-ok(check(), 'array : map');
+check('array : map');
 
 @b = grep { defined && $_ >= ord('b') } @a;
 ++$x[2];
-ok(check(), 'array : grep');
+check('array : grep');
 
 for (@a) { }
 $x[2] += 5;
-ok(check(), 'array : for');
+check('array : for');
 
 {
  my @b = @n;
  cast @b, $wiz;
 }
 ++$x[4];
-ok(check(), 'array : scope end');
+check('array : scope end');
 
 undef @a;
-++$x[3] if $^V && $^V gt 5.9.4; # since 5.9.5 - see #43357
-ok(check(), 'array : undef');
+++$x[3] if VMG_COMPAT_ARRAY_UNDEF_CLEAR;
+check('array : undef');
 
 dispell @a, $wiz;
-ok(check(), 'array : dispel');
+check('array : dispel');