The state() implementation is not yet perfect. Check in a new todo test
Rafael Garcia-Suarez [Thu, 6 Jul 2006 16:55:57 +0000 (16:55 +0000)]
p4raw-id: //depot/perl@28498

t/op/state.t

index 31347b1..becbb3b 100644 (file)
@@ -10,7 +10,7 @@ BEGIN {
 use strict;
 use feature "state";
 
-plan tests => 32;
+plan tests => 34;
 
 ok( ! defined state $uninit, q(state vars are undef by default) );
 
@@ -105,6 +105,7 @@ is( gen_cashier()->{bal}->(), 42, '$42 in my drawer' );
 # stateless assignment to a state variable
 
 sub stateless {
+    no warnings 'misc';
     (state $reinitme, my $foo) = (42, 'bar');
     ++$reinitme;
 }
@@ -152,3 +153,17 @@ my $ls = statelist();
 is($ls, "12/23", 'list assignment to state scalars');
 $ls = statelist();
 is($ls, "13/24", 'list assignment to state scalars');
+
+sub statelist2 {
+    state($sherry, $bourbon) = (1 .. 2);
+    $sherry++;
+    $bourbon++;
+    "$sherry/$bourbon";
+}
+
+$ls = statelist2();
+is($ls, "2/3", 'list assignment to state scalars');
+$ls = statelist2();
+{ local our $TODO = 'detection of state vars is misplaced in newASSIGNOP';
+is($ls, "3/4", 'list assignment to state scalars');
+}