f7c2c6b1f9ed535f51bcbcc00a88cd17f49fd2bd
[p5sagit/Class-Accessor-Grouped.git] / t / accessors_xs_cachedwarn.t
1 use strict;
2 use warnings;
3 use Test::More;
4 use lib 't/lib';
5
6 BEGIN {
7   plan skip_all => "Sub::Name not available"
8     unless eval { require Sub::Name };
9
10   require Class::Accessor::Grouped;
11
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 $@;
19 }
20
21 use AccessorGroupsSubclass;
22
23 my $obj = AccessorGroupsSubclass->new;
24 my $deferred_stub = AccessorGroupsSubclass->can('singlefield');
25 my $obj2 = AccessorGroups->new;
26
27 my @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');
34
35   is ($obj->singlefield, 2, 'Normal get');
36   is ($obj2->singlefield, undef, 'Normal get on unrelated object');
37 }
38
39 is (@w, 3, '3 warnings total');
40
41 is (
42   scalar (grep { $_ =~ /^\QDeferred version of method AccessorGroupsParent::singlefield invoked more than once/ } @w),
43   3,
44   '3 warnings produced as expected on cached invocation during testing',
45 ) or do {
46   require Data::Dumper;
47   diag "\n \$0 is: " . Data::Dumper->new([$0])->Useqq(1)->Terse(1)->Dump;
48 };
49
50 done_testing;