Get rid of subtests so we can test threads
[p5sagit/Class-Accessor-Grouped.git] / t / accessors_xs_cachedwarn.t
CommitLineData
e6f2993f 1use strict;
2use warnings;
e6f2993f 3use Test::More;
4use lib 't/lib';
5
6BEGIN {
7a1ba8bd 7 plan skip_all => "Sub::Name not available"
8 unless eval { require Sub::Name };
9
ba8c183b 10 require Class::Accessor::Grouped;
7a1ba8bd 11
ba8c183b 12 my $xsa_ver = $Class::Accessor::Grouped::__minimum_xsa_version;
13 eval {
14 require Class::XSAccessor;
15 Class::XSAccessor->VERSION ($xsa_ver);
16 };
17 plan skip_all => "Class::XSAccessor >= $xsa_ver not available"
18 if $@;
e6f2993f 19}
20
21use AccessorGroupsSubclass;
e6f2993f 22
23my $obj = AccessorGroupsSubclass->new;
24my $deferred_stub = AccessorGroupsSubclass->can('singlefield');
5808b224 25my $obj2 = AccessorGroups->new;
e6f2993f 26
27my @w;
28{
29 local $SIG{__WARN__} = sub { push @w, @_ };
30 is ($obj->$deferred_stub(1), 1, 'Set');
31 is ($obj->$deferred_stub, 1, 'Get');
32 is ($obj->$deferred_stub(2), 2, 'ReSet');
33 is ($obj->$deferred_stub, 2, 'ReGet');
34051fe0 34
35 is ($obj->singlefield, 2, 'Normal get');
36 is ($obj2->singlefield, undef, 'Normal get on unrelated object');
e6f2993f 37}
38
34051fe0 39is (@w, 3, '3 warnings total');
40
e6f2993f 41is (
5808b224 42 scalar (grep { $_ =~ /^\QDeferred version of method AccessorGroupsParent::singlefield invoked more than once/ } @w),
6026fe65 43 3,
44 '3 warnings produced as expected on cached invocation during testing',
21498f4a 45) or do {
46 require Data::Dumper;
47 diag "\n \$0 is: " . Data::Dumper->new([$0])->Useqq(1)->Terse(1)->Dump;
48};
e6f2993f 49
50done_testing;