X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Fharness;h=f7239fe3b177e055eb261824540ae248383389ca;hb=4cd2bd1f390724a103e72b993d7f67fb405628ad;hp=011dc6329c854ceb56d5bacf0826b63de83c467a;hpb=b637ffadabdd74cf3d1ad745a96611c427d33ba5;p=p5sagit%2Fp5-mst-13.2.git
diff --git a/t/harness b/t/harness
index 011dc63..f7239fe 100644
--- a/t/harness
+++ b/t/harness
@@ -5,16 +5,26 @@
BEGIN {
chdir 't' if -d 't';
- unshift @INC, '../lib';
+ @INC = '../lib'; # pick up only this build's lib
$ENV{PERL5LIB} = '../lib'; # so children will see it too
}
-use lib '../lib';
+
+my $torture; # torture testing?
use Test::Harness;
$Test::Harness::switches = ""; # Too much noise otherwise
$Test::Harness::verbose = shift if @ARGV && $ARGV[0] eq '-v';
+if ($ARGV[0] eq '-torture') {
+ shift;
+ $torture = 1;
+}
+
+# Let tests know they're running in the perl core. Useful for modules
+# which live dual lives on CPAN.
+$ENV{PERL_CORE} = 1;
+
#fudge DATA for now.
%datahandle = qw(
lib/bigint.t 1
@@ -29,31 +39,53 @@ $Test::Harness::verbose = shift if @ARGV && $ARGV[0] eq '-v';
op/runlevel.t 1
op/tie.t 1
op/lex_assign.t 1
- pragma/subs.t 1
);
foreach (keys %datahandle) {
unlink "$_.t";
}
+my @tests = ();
+
if (@ARGV) {
- @tests = @ARGV;
+ if ($^O eq 'MSWin32') {
+ @tests = map(glob($_),@ARGV);
+ }
+ else {
+ @tests = @ARGV;
+ }
} else {
- @tests = unless @tests;
- use File::Spec;
- my $updir = File::Spec->updir;
- my $mani = File::Spec->catdir(File::Spec->updir, "MANIFEST");
- if (open(MANI, $mani)) {
- while () {
- if (m!^((?:ext|lib)/.+/(?:t/.+\.t)|test.pl)\s!) {
- push @tests, File::Spec->catdir($updir, $1);
+ unless (@tests) {
+ push @tests, ;
+ push @tests, ;
+ push @tests, ;
+ push @tests, ;
+ push @tests, ;
+ push @tests, ;
+ push @tests, ;
+ push @tests, ;
+ push @tests, if $torture;
+ push @tests, if $^O eq 'MSWin32';
+ use File::Spec;
+ my $updir = File::Spec->updir;
+ my $mani = File::Spec->catfile(File::Spec->updir, "MANIFEST");
+ if (open(MANI, $mani)) {
+ while () { # similar code in t/TEST
+ if (m!^(ext/\S+/?(?:[^/\s]+\.t|test\.pl)|lib/\S+?(?:\.t|test\.pl))\s!) {
+ push @tests, File::Spec->catfile($updir, $1);
+ }
}
+ close MANI;
+ } else {
+ warn "$0: cannot open $mani: $!\n";
}
- } else {
- warn "$0: cannot open $mani: $!\n";
+ push @tests, ;
+ push @tests, ;
}
}
-
+if ($^O eq 'MSWin32') {
+ s,\\,/,g for @tests;
+}
Test::Harness::runtests @tests;
exit(0) unless -e "../testcompile";