Get rid of subtests so we can test threads
[p5sagit/Class-Accessor-Grouped.git] / t / accessors_xs.t
CommitLineData
9540f4e4 1use strict;
2use warnings;
3use FindBin qw($Bin);
4use File::Spec::Functions;
cfed50f2 5use File::Spec::Unix (); # need this for %INC munging
9540f4e4 6use Test::More;
7use lib 't/lib';
8
8019c4d8 9BEGIN {
7a1ba8bd 10 plan skip_all => "Sub::Name not available"
11 unless eval { require Sub::Name };
12
ba8c183b 13 require Class::Accessor::Grouped;
7a1ba8bd 14
ba8c183b 15 my $xsa_ver = $Class::Accessor::Grouped::__minimum_xsa_version;
16 eval {
17 require Class::XSAccessor;
18 Class::XSAccessor->VERSION ($xsa_ver);
19 };
20 plan skip_all => "Class::XSAccessor >= $xsa_ver not available"
21 if $@;
8019c4d8 22}
9540f4e4 23
28344104 24# rerun the regular 3 tests under XSAccessor
ed606987 25our $SUBTESTING = 1;
8019c4d8 26$Class::Accessor::Grouped::USE_XS = 1;
cfed50f2 27
ed606987 28for my $tname (qw/accessors.t accessors_ro.t accessors_wo.t/) {
29
30 for (1,2) {
31 note "\nTesting $tname with USE_XS (pass $_)\n\n";
32
cfed50f2 33 my $tfn = catfile($Bin, $tname);
34
f7cf6867 35 for (
5808b224 36 qw|AccessorGroups.pm AccessorGroups/BeenThereDoneThat.pm AccessorGroupsRO.pm AccessorGroupsSubclass.pm AccessorGroupsParent.pm AccessorGroupsWO.pm|,
cfed50f2 37 File::Spec::Unix->catfile ($tfn),
f7cf6867 38 ) {
39 delete $INC{$_};
40 no strict 'refs';
41 if (my ($mod) = $_ =~ /(.+)\.pm$/ ) {
42 %{"${mod}::"} = ();
43 }
44 }
cfed50f2 45
46 local $SIG{__WARN__} = sub { warn @_ unless $_[0] =~ /subroutine .+ redefined/i };
47
48 do($tfn);
ed606987 49 }
8019c4d8 50}
51
52done_testing;