X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Faccessors_xs_cachedwarn.t;h=c8e659b944730c165205097824e553978600abe4;hb=270b8b0ff6a3a40932caa937459e884904d9dd49;hp=14149c5acf6406ff5e48cfa7cfcd5e9a43e6326d;hpb=34051fe079d446e860cc2c6240488abfad3f85ac;p=p5sagit%2FClass-Accessor-Grouped.git diff --git a/t/accessors_xs_cachedwarn.t b/t/accessors_xs_cachedwarn.t index 14149c5..c8e659b 100644 --- a/t/accessors_xs_cachedwarn.t +++ b/t/accessors_xs_cachedwarn.t @@ -1,47 +1,70 @@ +my $has_threads; +BEGIN { eval ' + use 5.008005; # older perls get confused by $SIG fiddling under CXSA + 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 $obj2 = AccessorGroups->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'); - - is ($obj->singlefield, 2, 'Normal get'); - is ($obj2->singlefield, undef, 'Normal get on unrelated object'); + 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'); + + 42; + }; + + is ( + ($has_threads ? threads->create( $todo )->join : $todo->()), + 42, + "Correct result after do-er", + ) } 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;