xsubpp 1.924
[p5sagit/p5-mst-13.2.git] / t / TEST
diff --git a/t/TEST b/t/TEST
old mode 100644 (file)
new mode 100755 (executable)
index abfa65a..dfe429a
--- a/t/TEST
+++ b/t/TEST
@@ -1,6 +1,6 @@
 #!./perl
 
-# $RCSfile: TEST,v $$Revision: 4.0.1.1 $$Date: 91/06/07 11:59:30 $
+# $RCSfile: TEST,v $$Revision: 4.1 $$Date: 92/08/07 18:27:00 $
 
 # This is written in a peculiar style, since we're trying to avoid
 # most of the constructs we'll be testing for.
@@ -14,6 +14,11 @@ if ($ARGV[0] eq '-v') {
 
 chdir 't' if -f 't/TEST';
 
+die "You need to run \"make test\" first to set things up.\n" 
+  unless -e 'perl' or -e 'perl.exe';
+
+$ENV{EMXSHELL} = 'sh';        # For OS/2
+
 if ($ARGV[0] eq '') {
     @ARGV = split(/[ \n]/,
       `echo base/*.t comp/*.t cmd/*.t io/*.t; echo op/*.t lib/*.t`);
@@ -27,6 +32,8 @@ while (<CONFIG>) {
     }
 }
 $bad = 0;
+$good = 0;
+$total = @ARGV;
 while ($test = shift) {
     if ($test =~ /^$/) {
        next;
@@ -35,7 +42,7 @@ while ($test = shift) {
     chop($te);
     print "$te" . '.' x (15 - length($te));
     if ($sharpbang) {
-       open(results,"./$test|") || (print "can't run.\n");
+       open(results,"./$test |") || (print "can't run.\n");
     } else {
        open(script,"$test") || die "Can't run $test.\n";
        $_ = <script>;
@@ -45,7 +52,7 @@ while ($test = shift) {
        } else {
            $switch = '';
        }
-       open(results,"./perl$switch $test|") || (print "can't run.\n");
+       open(results,"./perl$switch $test |") || (print "can't run.\n");
     }
     $ok = 0;
     $next = 0;
@@ -73,6 +80,7 @@ while ($test = shift) {
     $next = $next - 1;
     if ($ok && $next == $max) {
        print "ok\n";
+       $good = $good + 1;
     } else {
        $next += 1;
        print "FAILED on test $next\n";
@@ -91,10 +99,11 @@ if ($bad == 0) {
        die "FAILED--no tests were run for some reason.\n";
     }
 } else {
+    $pct = sprintf("%.2f", $good / $total * 100);
     if ($bad == 1) {
-       die "Failed 1 test.\n";
+       warn "Failed 1 test, $pct% okay.\n";
     } else {
-       die "Failed $bad tests.\n";
+       die "Failed $bad/$total tests, $pct% okay.\n";
     }
 }
 ($user,$sys,$cuser,$csys) = times;