-use Test::More tests => 48;
+use Test::More;
use Test::Exception;
use strict;
use warnings;
+no warnings 'once';
use lib 't/lib';
# we test the pure-perl versions only, but allow overrides
# 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)/
+ ;
+
+ SKIP: {
+ skip "Class::XSAccessor emits broken error messages on 5.10 and earlier", 1 if (
+ $test_accessors->{$name}{is_xs}
+ and
+ $] < '5.011'
+ );
# 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
-1;
+done_testing unless $::SUBTESTING;