]> git.vpit.fr Git - perl/modules/Variable-Magic.git/commitdiff
Complete coverage of the len callback
authorVincent Pit <vince@profvince.com>
Sat, 24 Apr 2010 21:46:47 +0000 (23:46 +0200)
committerVincent Pit <vince@profvince.com>
Sat, 24 Apr 2010 21:46:47 +0000 (23:46 +0200)
t/22-len.t

index 7025e7bb1ffce743f0d70f5a83aef9a72dec3cac..01a06dd932ccc8ae70f34f3c838ccd853f56c5dc 100644 (file)
@@ -3,7 +3,7 @@
 use strict;
 use warnings;
 
-use Test::More tests => 33 + (2 * 2 + 1);
+use Test::More tests => 39 + (2 * 2 + 1);
 
 use Variable::Magic qw/wizard cast dispell VMG_COMPAT_SCALAR_LENGTH_NOLEN/;
 
@@ -128,6 +128,35 @@ SKIP: {
  is $b, $d, 'len: get utf8 scalar length correctly';
 }
 
+{
+ our $c;
+ # length magic on scalars needs also get magic to be triggered.
+ my $wiz = wizard get => sub { 0 },
+                  len => sub { $d = $_[2]; ++$c; return $_[2] };
+
+ {
+  my $x = "banana";
+  cast $x, $wiz;
+
+  local $c = 0;
+  pos($x) = 2;
+  is $c, 1,        'len: pos scalar triggers magic correctly';
+  is $d, 6,        'len: pos scalar have correct default length';
+  is $x, 'banana', 'len: pos scalar works correctly'
+ }
+
+ {
+  my $x = "hl\x{20AB}gh"; # Force utf8 on string
+  cast $x, $wiz;
+
+  local $c = 0;
+  substr($x, 2, 1) = 'a';
+  is $c, 1,       'len: substr utf8 scalar triggers magic correctly';
+  is $d, 5,       'len: substr utf8 scalar have correct default length';
+  is $x, 'hlagh', 'len: substr utf8 scalar correctly';
+ }
+}
+
 {
  my @val = (4 .. 6);