This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
Make also hex() and oct() to croak if their arguments
[perl5.git] / t / harness
index 174b318..330cc43 100644 (file)
--- a/t/harness
+++ b/t/harness
@@ -5,34 +5,79 @@
 
 BEGIN {
     chdir 't' if -d 't';
-    unshift @INC, '../lib';
-    $ENV{PERL5LIB} = '../lib'; # so children will see it too
+    @INC = '../lib';              # pick up only this build's lib
+    $ENV{PERL5LIB} = '../lib';    # so children will see it too
 }
-use lib '../lib';
 
 use Test::Harness;
 
-$Test::Harness::switches = ""; # Too much noise otherwise
+$Test::Harness::switches = "";    # Too much noise otherwise
 $Test::Harness::verbose = shift if @ARGV && $ARGV[0] eq '-v';
 
-@tests = @ARGV;
-@tests = <base/*.t comp/*.t cmd/*.t io/*.t op/*.t pragma/*.t lib/*.t> unless @tests;
+# Let tests know they're running in the perl core.  Useful for modules
+# which live dual lives on CPAN.
+$ENV{PERL_CORE} = 1;
 
-Test::Harness::runtests @tests;
-exit(0) unless -e "../testcompile";
-
-%infinite =   qw(
-               op/bop.t                1
-               lib/hostname.t          1
-               );
 #fudge DATA for now.
 %datahandle = qw(
                lib/bigint.t            1
                lib/bigintpm.t          1
                lib/bigfloat.t          1
                lib/bigfloatpm.t        1
+               op/gv.t                 1
+               lib/complex.t           1
+               lib/ph.t                1
+               lib/soundex.t           1
+               op/misc.t               1
+               op/runlevel.t           1
+               op/tie.t                1
+               op/lex_assign.t         1
                );
 
+foreach (keys %datahandle) {
+     unlink "$_.t";
+}
+
+my @tests = ();
+
+if (@ARGV) {
+    @tests = @ARGV;
+} else {
+    unless (@tests) {
+       push @tests, <base/*.t>;
+        push @tests, <comp/*.t>;
+        push @tests, <cmd/*.t>;
+        push @tests, <run/*.t>;
+        push @tests, <io/*.t>;
+        push @tests, <op/*.t>;
+        push @tests, <uni/*.t>;
+        push @tests, <lib/*.t>;
+       use File::Spec;
+       my $updir = File::Spec->updir;
+       my $mani  = File::Spec->catfile(File::Spec->updir, "MANIFEST");
+       if (open(MANI, $mani)) {
+           while (<MANI>) { # similar code in t/TEST
+           if (m!^(ext/\S+/([^/]+\.t|test\.pl)|lib/\S+?(\.t|test\.pl))\s!) {
+                   push @tests, File::Spec->catfile($updir, $1);
+               }
+           }
+       } else {
+           warn "$0: cannot open $mani: $!\n";
+       }
+       push @tests, <pod/*.t>;
+    }
+}
+
+Test::Harness::runtests @tests;
+exit(0) unless -e "../testcompile";
+
+# %infinite =  qw (
+#        op/bop.t      1
+#        lib/hostname.t        1
+#       op/lex_assign.t        1
+#       lib/ph.t       1
+#        );
+
 my $dhwrapper = <<'EOT';
 open DATA,"<".__FILE__;
 until (($_=<DATA>) =~ /^__END__/) {};
@@ -40,22 +85,26 @@ EOT
 
 @tests = grep (!$infinite{$_}, @tests);
 @tests = map {
-                my $new = $_;
-                if ($datahandle{$_}) {
-                    $new .= '.t';
-                    local(*F, *T);
-                    open(F,"<$_") or die "Can't open $_: $!";
-                    open(T,">$new") or die "Can't open $new: $!";
-                    print T $dhwrapper, <F>;
-                    close F;
-                    close T;
-                }
-                $new;
-            } @tests;
-
-print "The tests ", join(' ', keys(%infinite)), 
-       " generate infinite loops! Skipping!\n";
-$ENV{'COMPILE_TEST'} = 1; Test::Harness::runtests @tests; 
+         my $new = $_;
+        if ($datahandle{$_} && !( -f "$new.t") ) {
+             $new .= '.t';
+             local(*F, *T);
+             open(F,"<$_") or die "Can't open $_: $!";
+             open(T,">$new") or die "Can't open $new: $!";
+             print T $dhwrapper, <F>;
+             close F;
+             close T;
+         }
+         $new;
+         } @tests;
+
+print "The tests ", join(' ', keys(%infinite)),
+    " generate infinite loops! Skipping!\n";
+
+$ENV{'HARNESS_COMPILE_TEST'} = 1;
+$ENV{'PERLCC_TIMEOUT'} = 120 unless $ENV{'PERLCC_TIMEOUT'};
+
+Test::Harness::runtests @tests;
 foreach (keys %datahandle) {
      unlink "$_.t";
 }