Require bugfixed CXSA and warn on old (unusable) versions
[p5sagit/Class-Accessor-Grouped.git] / t / accessors_ro.t
CommitLineData
4d70ba11 1use Test::More tests => 58;
8019c4d8 2use Test::Exception;
6a48652b 3use strict;
4use warnings;
395c3fdb 5use Config;
6a48652b 6use lib 't/lib';
8019c4d8 7
8# we test the pure-perl versions only, but allow overrides
9# from the accessor_xs test-umbrella
10# Also make sure a rogue envvar will not interfere with
11# things
12my $use_xs;
13BEGIN {
ba8c183b 14 $Class::Accessor::Grouped::USE_XS = 0
15 unless defined $Class::Accessor::Grouped::USE_XS;
16 $ENV{CAG_USE_XS} = 1;
17 $use_xs = $Class::Accessor::Grouped::USE_XS;
8019c4d8 18};
19
6a48652b 20use AccessorGroupsRO;
21
84430300 22my $obj = AccessorGroupsRO->new;
6a48652b 23
24{
ba8c183b 25 my $warned = 0;
6a48652b 26
ba8c183b 27 local $SIG{__WARN__} = sub {
28 if (shift =~ /DESTROY/i) {
29 $warned++;
6a48652b 30 };
ba8c183b 31 };
6a48652b 32
ba8c183b 33 no warnings qw/once/;
34 local *AccessorGroupsRO::DESTROY = sub {};
6a48652b 35
ba8c183b 36 $obj->mk_group_ro_accessors('warnings', 'DESTROY');
c26cc2b9 37
ba8c183b 38 ok($warned);
6a48652b 39};
40
8019c4d8 41my $test_accessors = {
ba8c183b 42 singlefield => {
43 is_xs => $use_xs,
44 },
45 multiple1 => {
46 },
47 multiple2 => {
48 },
49 lr1name => {
50 custom_field => 'lr1;field',
51 },
52 lr2name => {
53 custom_field => "lr2'field",
54 },
4d70ba11 55 fieldname_torture => {
79f0ccb0 56 custom_field => join ('', map { chr($_) } (0..255) ),
4d70ba11 57 is_xs => $use_xs,
58 },
8019c4d8 59};
60
61for my $name (sort keys %$test_accessors) {
62
ba8c183b 63 my $alias = "_${name}_accessor";
64 my $field = $test_accessors->{$name}{custom_field} || $name;
6a48652b 65
ba8c183b 66 can_ok($obj, $name, $alias);
6a48652b 67
ba8c183b 68 ok(!$obj->can($field))
69 if $field ne $name;
8019c4d8 70
ba8c183b 71 is($obj->$name, undef);
72 is($obj->$alias, undef);
6a48652b 73
ba8c183b 74 # get via name
75 $obj->{$field} = 'a';
76 is($obj->$name, 'a');
6a48652b 77
ba8c183b 78 # alias gets same as name
79 is($obj->$alias, 'a');
6a48652b 80
ba8c183b 81 my $ro_regex = $test_accessors->{$name}{is_xs}
82 ? qr/Usage\:.+$name.*\(self\)/
da609a46 83 : qr/$name(:?_accessor)?\Q' cannot alter its value (read-only attribute of class AccessorGroupsRO)/
ba8c183b 84 ;
8019c4d8 85
395c3fdb 86 {
87 local $TODO = "Class::XSAccessor emits broken error messages on 5.10 or -DDEBUGGING 5.8"
88 if (
89 $test_accessors->{$name}{is_xs}
90 and
91 $] < '5.011'
92 and
93 ( $] > '5.009' or $Config{config_args} =~ /DEBUGGING/ )
94 );
95
96 # die on set via name/alias
97 throws_ok {
98 $obj->$name('b');
99 } $ro_regex;
100
101 throws_ok {
102 $obj->$alias('b');
103 } $ro_regex;
104 }
6a48652b 105
ba8c183b 106 # value should be unchanged
107 is($obj->$name, 'a');
108 is($obj->$alias, 'a');
6a48652b 109};
110
8019c4d8 111#important
1121;