Get rid of subtests so we can test threads
[p5sagit/Class-Accessor-Grouped.git] / t / accessors.t
index 8bca250..e2ea1f7 100644 (file)
@@ -1,6 +1,7 @@
-use Test::More tests => 136;
+use Test::More;
 use strict;
 use warnings;
+no warnings 'once';
 use lib 't/lib';
 use B qw/svref_2object/;
 
@@ -26,7 +27,8 @@ my $test_accessors = {
   runtime_around => {
     # even though this accessor is declared as simple it will *not* be
     # reinstalled due to the runtime 'around'
-    #is_simple => 1,
+    forced_class => 'AccessorGroups',
+    is_simple => 1,
     has_extra => 1,
   },
   multiple1 => {
@@ -45,63 +47,92 @@ my $test_accessors = {
   },
 };
 
-for my $obj (
-  AccessorGroupsSubclass->new,
-) {
+for my $class (qw(
+  AccessorGroupsSubclass
+  AccessorGroups
+  AccessorGroupsParent
+)) {
+  my $obj = $class->new;
+
   for my $name (sort keys %$test_accessors) {
     my $alias = "_${name}_accessor";
     my $field = $test_accessors->{$name}{custom_field} || $name;
     my $extra = $test_accessors->{$name}{has_extra};
+    my $origin_class = 'AccessorGroupsParent';
+
+    if ( $class eq 'AccessorGroupsParent' ) {
+      next if $name eq 'runtime_around';  # implemented in the AG subclass
+      $extra = 0;
+    }
+    elsif ($name eq 'fieldname_torture') {
+      $field = reverse $field;
+      $origin_class = 'AccessorGroups';
+    }
 
     can_ok($obj, $name, $alias);
-    ok(!$obj->can($field))
+    ok(!$obj->can($field), "field for $name is not a method on $class")
       if $field ne $name;
 
+    my $init_shims;
+
     # initial method name
     for my $meth ($name, $alias) {
-      my $cv = svref_2object( $obj->can($meth) );
-      is($cv->GV->NAME, $meth, "initial $meth accessor is named");
+      my $cv = svref_2object( $init_shims->{$meth} = $obj->can($meth) );
+      is($cv->GV->NAME, $meth, "initial ${class}::$meth accessor is named");
       is(
         $cv->GV->STASH->NAME,
-        'AccessorGroups',
-        "initial $meth class correct",
+        $test_accessors->{$name}{forced_class} || $origin_class,
+        "initial ${class}::$meth origin class correct",
       );
     }
 
-    is($obj->$name, undef);
-    is($obj->$alias, undef);
+    is($obj->$name, undef, "${class}::$name begins undef");
+    is($obj->$alias, undef, "${class}::$alias begins undef");
 
     # get/set via name
-    is($obj->$name('a'), 'a');
-    is($obj->$name, 'a');
-    is($obj->{$field}, $extra ? 'a Extra tackled on' : 'a');
+    is($obj->$name('a'), 'a', "${class}::$name setter RV correct");
+    is($obj->$name, 'a', "${class}::$name getter correct");
+    is($obj->{$field}, $extra ? 'a Extra tackled on' : 'a', "${class}::$name corresponding field correct");
 
     # alias gets same as name
-    is($obj->$alias, 'a');
+    is($obj->$alias, 'a', "${class}::$alias getter correct after ${class}::$name setter");
 
     # get/set via alias
-    is($obj->$alias('b'), 'b');
-    is($obj->$alias, 'b');
-    is($obj->{$field}, $extra ? 'b Extra tackled on' : 'b');
+    is($obj->$alias('b'), 'b', "${class}::$alias setter RV correct");
+    is($obj->$alias, 'b', "${class}::$alias getter correct");
+    is($obj->{$field}, $extra ? 'b Extra tackled on' : 'b', "${class}::$alias corresponding field still correct");
 
     # alias gets same as name
-    is($obj->$name, 'b');
+    is($obj->$name, 'b', "${class}::$name getter correct after ${class}::$alias setter");
 
     for my $meth ($name, $alias) {
-      my $cv = svref_2object( $obj->can($meth) );
+      my $resolved = $obj->can($meth);
+
+      my $cv = svref_2object($resolved);
       is($cv->GV->NAME, $meth, "$meth accessor is named after operations");
       is(
         $cv->GV->STASH->NAME,
         # XS deferred subs install into each caller, not into the original parent
-        ($use_xs and $test_accessors->{$name}{is_simple})
-          ? ref $obj
-          : 'AccessorGroups'
-        ,
-        "$meth class correct after operations",
+        $test_accessors->{$name}{forced_class} || (
+          ($use_xs and $test_accessors->{$name}{is_simple})
+            ? (ref $obj)
+            : $origin_class
+        ),
+        "${class}::$meth origin class correct after operations",
       );
+
+      # just simple for now
+      if ($use_xs and $test_accessors->{$name}{is_simple} and ! $test_accessors->{$name}{forced_class}) {
+        ok ($resolved != $init_shims->{$meth}, "$meth was replaced with a resolved version");
+        if ($class eq 'AccessorGroupsParent') {
+          ok ($cv->XSUB, "${class}::$meth is an XSUB");
+        }
+        else {
+          ok (!$cv->XSUB, "${class}::$meth is *not* an XSUB (due to get_simple overrides)");
+        }
+      }
     }
   }
 }
 
-# important
-1;
+done_testing unless $::SUBTESTING;