X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Faccessors_xs_cachedwarn.t;h=eecc8dff23908ec4a07fec0366b57434d24a1f59;hb=1ed25f9e8d107a7311c579da0d23afa253c01268;hp=acc1f484dcc5603148e3fff4b5f5e82694bb7e00;hpb=6026fe65dd079309ddbb6145aaca95007c480aa7;p=p5sagit%2FClass-Accessor-Grouped.git diff --git a/t/accessors_xs_cachedwarn.t b/t/accessors_xs_cachedwarn.t index acc1f48..eecc8df 100644 --- a/t/accessors_xs_cachedwarn.t +++ b/t/accessors_xs_cachedwarn.t @@ -1,41 +1,64 @@ +my $has_threads; +BEGIN { eval ' + use 5.008004; # older perls get confused by $SIG fiddling + use threads; + use threads::shared; + $has_threads = 1; +' } + use strict; use warnings; -use FindBin qw($Bin); -use File::Spec::Functions; -use File::Spec::Unix (); # need this for %INC munging use Test::More; use lib 't/lib'; BEGIN { - require Class::Accessor::Grouped; - my $xsa_ver = $Class::Accessor::Grouped::__minimum_xsa_version; - eval { - require Class::XSAccessor; - Class::XSAccessor->VERSION ($xsa_ver); - }; - plan skip_all => "Class::XSAccessor >= $xsa_ver not available" - if $@; + plan skip_all => "Sub::Name not available" + unless eval { require Sub::Name }; + + require Class::Accessor::Grouped; + + my $xsa_ver = $Class::Accessor::Grouped::__minimum_xsa_version; + eval { + require Class::XSAccessor; + Class::XSAccessor->VERSION ($xsa_ver); + }; + plan skip_all => "Class::XSAccessor >= $xsa_ver not available" + if $@; } use AccessorGroupsSubclass; -$Class::Accessor::Grouped::USE_XS = 1; - -my $obj = AccessorGroupsSubclass->new; -my $deferred_stub = AccessorGroupsSubclass->can('singlefield'); my @w; +share(@w) if $has_threads; + { - local $SIG{__WARN__} = sub { push @w, @_ }; - is ($obj->$deferred_stub(1), 1, 'Set'); - is ($obj->$deferred_stub, 1, 'Get'); - is ($obj->$deferred_stub(2), 2, 'ReSet'); - is ($obj->$deferred_stub, 2, 'ReGet'); + my $obj = AccessorGroupsSubclass->new; + my $deferred_stub = AccessorGroupsSubclass->can('singlefield'); + my $obj2 = AccessorGroups->new; + + my $todo = sub { + local $SIG{__WARN__} = sub { push @w, @_ }; + is ($obj->$deferred_stub(1), 1, 'Set'); + is ($obj->$deferred_stub, 1, 'Get'); + is ($obj->$deferred_stub(2), 2, 'ReSet'); + is ($obj->$deferred_stub, 2, 'ReGet'); + + is ($obj->singlefield, 2, 'Normal get'); + is ($obj2->singlefield, undef, 'Normal get on unrelated object'); + }; + + $has_threads ? threads->create( $todo )->join : $todo->(); } +is (@w, 3, '3 warnings total'); + is ( - scalar (grep { $_ =~ /^\QDeferred version of method AccessorGroups::singlefield invoked more than once/ } @w), + scalar (grep { $_ =~ /^\QDeferred version of method AccessorGroupsParent::singlefield invoked more than once/ } @w), 3, '3 warnings produced as expected on cached invocation during testing', -); +) or do { + require Data::Dumper; + diag "\n \$0 is: " . Data::Dumper->new([$0])->Useqq(1)->Terse(1)->Dump; +}; done_testing;