Fix another XSA corner case - how can something so simple get so complex...
[p5sagit/Class-Accessor-Grouped.git] / t / accessors.t
CommitLineData
1ee74bdd 1use Test::More tests => 62;
e7d391a8 2use strict;
3use warnings;
4use lib 't/lib';
8019c4d8 5use Sub::Identify qw/sub_name sub_fullname/;
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
19use AccessorGroups;
9540f4e4 20
e7d391a8 21my $class = AccessorGroups->new;
22
23{
24 my $warned = 0;
25
26 local $SIG{__WARN__} = sub {
27 if (shift =~ /DESTROY/i) {
28 $warned++;
29 };
30 };
31
32 $class->mk_group_accessors('warnings', 'DESTROY');
33
34 ok($warned);
c26cc2b9 35
36 # restore non-accessorized DESTROY
37 no warnings;
38 *AccessorGroups::DESTROY = sub {};
e7d391a8 39};
40
1ee74bdd 41{
42 my $class_name = ref $class;
43 my $name = 'multiple1';
44 my $alias = "_${name}_accessor";
45 my $accessor = $class->can($name);
46 my $alias_accessor = $class->can($alias);
47 isnt(sub_name($accessor), '__ANON__', 'accessor is named');
48 isnt(sub_name($alias_accessor), '__ANON__', 'alias is named');
49 is(sub_fullname($accessor), join('::',$class_name,$name), 'accessor FQ name');
50 is(sub_fullname($alias_accessor), join('::',$class_name,$alias), 'alias FQ name');
51}
52
28344104 53my $test_accessors = {
54 singlefield => {
55 is_xs => $use_xs,
fee7c68b 56 has_extra => 1,
28344104 57 },
58 multiple1 => {
59 },
60 multiple2 => {
61 },
62 lr1name => {
63 custom_field => 'lr1;field',
64 },
65 lr2name => {
66 custom_field => "lr2'field",
67 },
68};
69
70
71for my $name (sort keys %$test_accessors) {
e7d391a8 72 my $alias = "_${name}_accessor";
28344104 73 my $field = $test_accessors->{$name}{custom_field} || $name;
fee7c68b 74 my $extra = $test_accessors->{$name}{has_extra};
e7d391a8 75
76 can_ok($class, $name, $alias);
28344104 77 ok(!$class->can($field))
78 if $field ne $name;
e7d391a8 79
80 is($class->$name, undef);
81 is($class->$alias, undef);
82
83 # get/set via name
84 is($class->$name('a'), 'a');
85 is($class->$name, 'a');
fee7c68b 86 is($class->{$field}, $extra ? 'a Extra tackled on' : 'a');
e7d391a8 87
88 # alias gets same as name
89 is($class->$alias, 'a');
90
91 # get/set via alias
92 is($class->$alias('b'), 'b');
93 is($class->$alias, 'b');
fee7c68b 94 is($class->{$field}, $extra ? 'b Extra tackled on' : 'b');
e7d391a8 95
96 # alias gets same as name
97 is($class->$name, 'b');
98};
99
8019c4d8 100# important
9540f4e4 1011;