1
use Test::More tests => 62;
1
use Test::More tests => 117;
5
use Sub::Identify qw/sub_name sub_fullname/;
5
use B qw/svref_2object/;
7
7
# we test the pure-perl versions only, but allow overrides
8
8
# from the accessor_xs test-umbrella
9
9
# Also make sure a rogue envvar will not interfere with
12
13
$Class::Accessor::Grouped::USE_XS = 0
13
14
unless defined $Class::Accessor::Grouped::USE_XS;
14
15
$ENV{CAG_USE_XS} = 1;
16
$use_xs = $Class::Accessor::Grouped::USE_XS;
19
my $class = AccessorGroups->new;
19
use AccessorGroupsSubclass;
22
my $obj = AccessorGroupsSubclass->new;
24
my $name = 'multiple1';
25
my $alias = "_${name}_accessor";
24
28
local $SIG{__WARN__} = sub {
25
29
if (shift =~ /DESTROY/i) {
35
local *AccessorGroupsSubclass::DESTROY = sub {};
30
37
$class->mk_group_accessors('warnings', 'DESTROY');
34
# restore non-accessorized DESTROY
36
*AccessorGroups::DESTROY = sub {};
40
my $class_name = ref $class;
41
my $name = 'multiple1';
42
my $alias = "_${name}_accessor";
43
my $accessor = $class->can($name);
44
my $alias_accessor = $class->can($alias);
45
isnt(sub_name($accessor), '__ANON__', 'accessor is named');
46
isnt(sub_name($alias_accessor), '__ANON__', 'alias is named');
47
is(sub_fullname($accessor), join('::',$class_name,$name), 'accessor FQ name');
48
is(sub_fullname($alias_accessor), join('::',$class_name,$alias), 'alias FQ name');
51
foreach (qw/singlefield multiple1 multiple2/) {
53
my $alias = "_${name}_accessor";
55
can_ok($class, $name, $alias);
57
is($class->$name, undef);
58
is($class->$alias, undef);
61
is($class->$name('a'), 'a');
62
is($class->$name, 'a');
63
is($class->{$name}, 'a');
65
# alias gets same as name
66
is($class->$alias, 'a');
69
is($class->$alias('b'), 'b');
70
is($class->$alias, 'b');
71
is($class->{$name}, 'b');
73
# alias gets same as name
74
is($class->$name, 'b');
77
foreach (qw/lr1 lr2/) {
78
my $name = "$_".'name';
79
my $alias = "_${name}_accessor";
81
my $field = { lr1 => 'lr1;field', lr2 => q{lr2'field} }->{$_};
83
can_ok($class, $name, $alias);
84
ok(!$class->can($field));
86
is($class->$name, undef);
87
is($class->$alias, undef);
90
is($class->$name('c'), 'c');
91
is($class->$name, 'c');
92
is($class->{$field}, 'c');
94
# alias gets same as name
95
is($class->$alias, 'c');
98
is($class->$alias('d'), 'd');
99
is($class->$alias, 'd');
100
is($class->{$field}, 'd');
102
# alias gets same as name
103
is($class->$name, 'd');
41
my $obj = AccessorGroupsSubclass->new;
43
my $test_accessors = {
49
# even though this accessor is simple it will *not* be XSified
50
# due to the runtime 'around'
59
custom_field => 'lr1;field',
62
custom_field => "lr2'field",
66
for my $name (sort keys %$test_accessors) {
67
my $alias = "_${name}_accessor";
68
my $field = $test_accessors->{$name}{custom_field} || $name;
69
my $extra = $test_accessors->{$name}{has_extra};
71
can_ok($obj, $name, $alias);
72
ok(!$obj->can($field))
75
for my $meth ($name, $alias) {
76
my $cv = svref_2object( $obj->can($meth) );
77
is($cv->GV->NAME, $meth, "$meth accessor is named");
78
is($cv->GV->STASH->NAME, 'AccessorGroups', "$meth class correct");
81
is($obj->$name, undef);
82
is($obj->$alias, undef);
85
is($obj->$name('a'), 'a');
87
is($obj->{$field}, $extra ? 'a Extra tackled on' : 'a');
89
# alias gets same as name
90
is($obj->$alias, 'a');
93
is($obj->$alias('b'), 'b');
94
is($obj->$alias, 'b');
95
is($obj->{$field}, $extra ? 'b Extra tackled on' : 'b');
97
# alias gets same as name
100
for my $meth ($name, $alias) {
101
my $cv = svref_2object( $obj->can($meth) );
102
is($cv->GV->NAME, $meth, "$meth accessor is named after operations");
104
$cv->GV->STASH->NAME,
105
# XS lazyinstalls install into each caller, not into the original parent
106
$test_accessors->{$name}{is_xs} ? 'AccessorGroupsSubclass' :'AccessorGroups',
107
"$meth class correct after operations",