Require bugfixed CXSA and warn on old (unusable) versions
[p5sagit/Class-Accessor-Grouped.git] / t / accessors_ro.t
index 4268b25..f9427b1 100644 (file)
@@ -1,7 +1,8 @@
-use Test::More tests => 48;
+use Test::More tests => 58;
 use Test::Exception;
 use strict;
 use warnings;
+use Config;
 use lib 't/lib';
 
 # we test the pure-perl versions only, but allow overrides
@@ -10,87 +11,101 @@ use lib 't/lib';
 # things
 my $use_xs;
 BEGIN {
-    $Class::Accessor::Grouped::USE_XS = 0
-        unless defined $Class::Accessor::Grouped::USE_XS;
-    $ENV{CAG_USE_XS} = 1;
-    $use_xs = $Class::Accessor::Grouped::USE_XS;
+  $Class::Accessor::Grouped::USE_XS = 0
+    unless defined $Class::Accessor::Grouped::USE_XS;
+  $ENV{CAG_USE_XS} = 1;
+  $use_xs = $Class::Accessor::Grouped::USE_XS;
 };
 
 use AccessorGroupsRO;
 
-my $class = AccessorGroupsRO->new;
+my $obj = AccessorGroupsRO->new;
 
 {
-    my $warned = 0;
+  my $warned = 0;
 
-    local $SIG{__WARN__} = sub {
-        if  (shift =~ /DESTROY/i) {
-            $warned++;
-        };
+  local $SIG{__WARN__} = sub {
+    if  (shift =~ /DESTROY/i) {
+      $warned++;
     };
+  };
 
-    $class->mk_group_ro_accessors('warnings', 'DESTROY');
+  no warnings qw/once/;
+  local *AccessorGroupsRO::DESTROY = sub {};
 
-    ok($warned);
+  $obj->mk_group_ro_accessors('warnings', 'DESTROY');
 
-    # restore non-accessorized DESTROY
-    no warnings;
-    *AccessorGroupsRO::DESTROY = sub {};
+  ok($warned);
 };
 
 my $test_accessors = {
-    singlefield => {
-        is_xs => $use_xs,
-    },
-    multiple1 => {
-    },
-    multiple2 => {
-    },
-    lr1name => {
-        custom_field => 'lr1;field',
-    },
-    lr2name => {
-        custom_field => "lr2'field",
-    },
+  singlefield => {
+    is_xs => $use_xs,
+  },
+  multiple1 => {
+  },
+  multiple2 => {
+  },
+  lr1name => {
+    custom_field => 'lr1;field',
+  },
+  lr2name => {
+    custom_field => "lr2'field",
+  },
+  fieldname_torture => {
+    custom_field => join ('', map { chr($_) } (0..255) ),
+    is_xs => $use_xs,
+  },
 };
 
 for my $name (sort keys %$test_accessors) {
 
-    my $alias = "_${name}_accessor";
-    my $field = $test_accessors->{$name}{custom_field} || $name;
+  my $alias = "_${name}_accessor";
+  my $field = $test_accessors->{$name}{custom_field} || $name;
 
-    can_ok($class, $name, $alias);
+  can_ok($obj, $name, $alias);
 
-    ok(!$class->can($field))
-      if $field ne $name;
+  ok(!$obj->can($field))
+    if $field ne $name;
 
-    is($class->$name, undef);
-    is($class->$alias, undef);
+  is($obj->$name, undef);
+  is($obj->$alias, undef);
 
-    # get via name
-    $class->{$field} = 'a';
-    is($class->$name, 'a');
+  # get via name
+  $obj->{$field} = 'a';
+  is($obj->$name, 'a');
 
-    # alias gets same as name
-    is($class->$alias, 'a');
+  # alias gets same as name
+  is($obj->$alias, 'a');
 
-    my $ro_regex = $test_accessors->{$name}{is_xs}
-        ? qr/Usage\:.+$name.*\(self\)/
-        : qr/cannot alter the value of '\Q$field\E'/
-    ;
+  my $ro_regex = $test_accessors->{$name}{is_xs}
+    ? qr/Usage\:.+$name.*\(self\)/
+    : qr/$name(:?_accessor)?\Q' cannot alter its value (read-only attribute of class AccessorGroupsRO)/
+  ;
+
+  {
+    local $TODO = "Class::XSAccessor emits broken error messages on 5.10 or -DDEBUGGING 5.8"
+      if (
+        $test_accessors->{$name}{is_xs}
+          and
+        $] < '5.011'
+          and
+        ( $] > '5.009' or $Config{config_args} =~ /DEBUGGING/ )
+      );
 
     # die on set via name/alias
     throws_ok {
-        $class->$name('b');
+      $obj->$name('b');
     } $ro_regex;
 
     throws_ok {
-        $class->$alias('b');
+      $obj->$alias('b');
     } $ro_regex;
+  }
 
-    # value should be unchanged
-    is($class->$name, 'a');
-    is($class->$alias, 'a');
+  # value should be unchanged
+  is($obj->$name, 'a');
+  is($obj->$alias, 'a');
 };
 
 #important