Better check for XS-availability (and bump to M::I which provides it)
[p5sagit/Class-Accessor-Grouped.git] / t / accessors_ro.t
CommitLineData
c26cc2b9 1use Test::More tests => 48;
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 },
8019c4d8 55};
56
57for my $name (sort keys %$test_accessors) {
58
ba8c183b 59 my $alias = "_${name}_accessor";
60 my $field = $test_accessors->{$name}{custom_field} || $name;
6a48652b 61
ba8c183b 62 can_ok($obj, $name, $alias);
6a48652b 63
ba8c183b 64 ok(!$obj->can($field))
65 if $field ne $name;
8019c4d8 66
ba8c183b 67 is($obj->$name, undef);
68 is($obj->$alias, undef);
6a48652b 69
ba8c183b 70 # get via name
71 $obj->{$field} = 'a';
72 is($obj->$name, 'a');
6a48652b 73
ba8c183b 74 # alias gets same as name
75 is($obj->$alias, 'a');
6a48652b 76
ba8c183b 77 my $ro_regex = $test_accessors->{$name}{is_xs}
78 ? qr/Usage\:.+$name.*\(self\)/
79 : qr/cannot alter the value of '\Q$field\E'/
80 ;
8019c4d8 81
395c3fdb 82 {
83 local $TODO = "Class::XSAccessor emits broken error messages on 5.10 or -DDEBUGGING 5.8"
84 if (
85 $test_accessors->{$name}{is_xs}
86 and
87 $] < '5.011'
88 and
89 ( $] > '5.009' or $Config{config_args} =~ /DEBUGGING/ )
90 );
91
92 # die on set via name/alias
93 throws_ok {
94 $obj->$name('b');
95 } $ro_regex;
96
97 throws_ok {
98 $obj->$alias('b');
99 } $ro_regex;
100 }
6a48652b 101
ba8c183b 102 # value should be unchanged
103 is($obj->$name, 'a');
104 is($obj->$alias, 'a');
6a48652b 105};
106
8019c4d8 107#important
1081;