Add debugging of undefer code reentrancy when a test environment is detected
[p5sagit/Class-Accessor-Grouped.git] / t / accessors.t
CommitLineData
85ccab9a 1use Test::More tests => 98;
e7d391a8 2use strict;
3use warnings;
4use lib 't/lib';
d1dc76a1 5use B qw/svref_2object/;
e7d391a8 6
8019c4d8 7# we test the pure-perl versions only, but allow overrides
8# from the accessor_xs test-umbrella
9# Also make sure a rogue envvar will not interfere with
10# things
28344104 11my $use_xs;
9540f4e4 12BEGIN {
8019c4d8 13 $Class::Accessor::Grouped::USE_XS = 0
14 unless defined $Class::Accessor::Grouped::USE_XS;
15 $ENV{CAG_USE_XS} = 1;
28344104 16 $use_xs = $Class::Accessor::Grouped::USE_XS;
8019c4d8 17};
18
f7ce0ad4 19use AccessorGroupsSubclass;
e7d391a8 20
21{
d1dc76a1 22 my $obj = AccessorGroupsSubclass->new;
84430300 23 my $class = ref $obj;
24 my $name = 'multiple1';
25 my $alias = "_${name}_accessor";
d1dc76a1 26
e7d391a8 27 my $warned = 0;
e7d391a8 28 local $SIG{__WARN__} = sub {
29 if (shift =~ /DESTROY/i) {
30 $warned++;
31 };
32 };
33
84430300 34 no warnings qw/once/;
d1dc76a1 35 local *AccessorGroupsSubclass::DESTROY = sub {};
e7d391a8 36
f7ce0ad4 37 $class->mk_group_accessors('warnings', 'DESTROY');
e7d391a8 38 ok($warned);
f7ce0ad4 39};
40
f7ce0ad4 41my $obj = AccessorGroupsSubclass->new;
1ee74bdd 42
28344104 43my $test_accessors = {
44 singlefield => {
45 is_xs => $use_xs,
fee7c68b 46 has_extra => 1,
28344104 47 },
48 multiple1 => {
49 },
50 multiple2 => {
51 },
52 lr1name => {
53 custom_field => 'lr1;field',
54 },
55 lr2name => {
56 custom_field => "lr2'field",
57 },
58};
59
28344104 60for my $name (sort keys %$test_accessors) {
e7d391a8 61 my $alias = "_${name}_accessor";
28344104 62 my $field = $test_accessors->{$name}{custom_field} || $name;
fee7c68b 63 my $extra = $test_accessors->{$name}{has_extra};
e7d391a8 64
84430300 65 can_ok($obj, $name, $alias);
66 ok(!$obj->can($field))
28344104 67 if $field ne $name;
e7d391a8 68
85ccab9a 69 for my $meth ($name, $alias) {
70 my $cv = svref_2object( $obj->can($meth) );
71 is($cv->GV->NAME, $meth, "$meth accessor is named");
72 is($cv->GV->STASH->NAME, 'AccessorGroups', "$meth class correct");
73 }
74
84430300 75 is($obj->$name, undef);
76 is($obj->$alias, undef);
e7d391a8 77
78 # get/set via name
84430300 79 is($obj->$name('a'), 'a');
80 is($obj->$name, 'a');
81 is($obj->{$field}, $extra ? 'a Extra tackled on' : 'a');
e7d391a8 82
83 # alias gets same as name
84430300 84 is($obj->$alias, 'a');
e7d391a8 85
86 # get/set via alias
84430300 87 is($obj->$alias('b'), 'b');
88 is($obj->$alias, 'b');
89 is($obj->{$field}, $extra ? 'b Extra tackled on' : 'b');
e7d391a8 90
91 # alias gets same as name
84430300 92 is($obj->$name, 'b');
85ccab9a 93
94 for my $meth ($name, $alias) {
95 my $cv = svref_2object( $obj->can($meth) );
96 is($cv->GV->NAME, $meth, "$meth accessor is named after operations");
f7cf6867 97 is(
98 $cv->GV->STASH->NAME,
99 # XS lazyinstalls install into each caller, not into the original parent
100 $test_accessors->{$name}{is_xs} ? 'AccessorGroupsSubclass' :'AccessorGroups',
101 "$meth class correct after operations",
102 );
85ccab9a 103 }
e7d391a8 104};
105
8019c4d8 106# important
9540f4e4 1071;