X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2FTEST;h=ec8c8f2f1522103735fee4bf6e9f2022fdc2ed08;hb=80ffb5f93608b52314883335103c8837769171e3;hp=a684b2ab655b7837b7e9eb9d1081589e715b0814;hpb=fac76ed70b2818d69c47c57bd5b63a636a19a037;p=p5sagit%2Fp5-mst-13.2.git diff --git a/t/TEST b/t/TEST index a684b2a..ec8c8f2 100755 --- a/t/TEST +++ b/t/TEST @@ -1,15 +1,22 @@ #!./perl -# Last change: Fri Jan 10 09:57:03 WET 1997 - # This is written in a peculiar style, since we're trying to avoid # most of the constructs we'll be testing for. $| = 1; -if ($#ARGV >= 0 && $ARGV[0] eq '-v') { - $verbose = 1; - shift; +# Cheesy version of Getopt::Std. Maybe we should replace it with that. +if ($#ARGV >= 0) { + foreach my $idx (0..$#ARGV) { + next unless $ARGV[$idx] =~ /^-(\S+)$/; + $verbose = 1 if $1 eq 'v'; + $with_utf= 1 if $1 eq 'utf8'; + if ($1 =~ /^deparse(,.+)?$/) { + $deparse = 1; + $deparse_opts = $1; + } + splice(@ARGV, $idx, 1); + } } chdir 't' if -f 't/TEST'; @@ -17,128 +24,293 @@ 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'; +if ($ENV{PERL_3LOG}) { # Tru64 third(1) tool, see perlhack + unless (-x 'perl.third') { + unless (-x '../perl.third') { + die "You need to run \"make perl.third first.\n"; + } + else { + print "Symlinking ../perl.third as perl.third...\n"; + die "Failed to symlink: $!\n" + unless symlink("../perl.third", "perl.third"); + die "Symlinked but no executable perl.third: $!\n" + unless -x 'perl.third'; + } + } +} + +# check leakage for embedders +$ENV{PERL_DESTRUCT_LEVEL} = 2 unless exists $ENV{PERL_DESTRUCT_LEVEL}; + $ENV{EMXSHELL} = 'sh'; # For OS/2 -if ($#ARGV == -1) { - @ARGV = split(/[ \n]/, - `echo base/*.t comp/*.t cmd/*.t io/*.t; echo op/*.t pragma/*.t lib/*.t`); -} +# Roll your own File::Find! +use TestInit; +use File::Spec; +my $curdir = File::Spec->curdir; +my $updir = File::Spec->updir; + +sub _find_tests { + my($dir) = @_; + opendir DIR, $dir || die "Trouble opening $dir: $!"; + foreach my $f (sort { $a cmp $b } readdir DIR) { + next if $f eq $curdir or $f eq $updir; -if ($^O eq 'os2' || $^O eq 'qnx') { - $sharpbang = 0; + my $fullpath = File::Spec->catdir($dir, $f); + + _find_tests($fullpath) if -d $fullpath; + push @ARGV, $fullpath if $f =~ /\.t$/; + } } -else { - open(CONFIG, "../config.sh"); - while () { - if (/sharpbang='(.*)'/) { - $sharpbang = ($1 eq '#!'); - last; + +unless (@ARGV) { + foreach my $dir (qw(base comp cmd run io op pragma lib pod)) { + _find_tests($dir); + } + my $mani = File::Spec->catdir($updir, "MANIFEST"); + if (open(MANI, $mani)) { + while () { # similar code in t/harness + if (m!^(ext/.+/([^/]+\.t|test\.pl)|lib/.+(\.t|test\.pl))\s!) { + push @ARGV, $1; + $OVER{$1} = File::Spec->catdir($updir, $1); + } } + } else { + warn "$0: cannot open $mani: $!\n"; } - close(CONFIG); } -$bad = 0; -$good = 0; -$total = @ARGV; -$files = 0; -$totmax = 0; -while ($test = shift) { - if ($test =~ /^$/) { - next; +# Tests known to cause infinite loops for the perlcc tests. +# %infinite = ( 'comp/require.t', 1, 'op/bop.t', 1, 'lib/hostname.t', 1 ); +%infinite = (); + +if ($deparse) { + _testprogs('deparse', @ARGV); +} else { + _testprogs('perl', @ARGV); + _testprogs('compile', @ARGV) if (-e "../testcompile"); +} + +sub _testprogs { + $type = shift @_; + @tests = @_; + + print <<'EOT' if ($type eq 'compile'); +------------------------------------------------------------------------------ +TESTING COMPILER +------------------------------------------------------------------------------ +EOT + + print <<'EOT' if ($type eq 'deparse'); +------------------------------------------------------------------------------ +TESTING DEPARSER +------------------------------------------------------------------------------ +EOT + + $ENV{PERLCC_TIMEOUT} = 120 + if ($type eq 'compile' && !$ENV{PERLCC_TIMEOUT}); + + $bad = 0; + $good = 0; + $total = @tests; + $files = 0; + $totmax = 0; + my $maxlen = 0; + my $maxsuflen = 0; + foreach (@tests) { # The same code in lib/Test/Harness.pm:_run_all_tests + my $suf = /\.(\w+)$/ ? $1 : ''; + my $len = length; + my $suflen = length $suf; + $maxlen = $len if $len > $maxlen; + $maxsuflen = $suflen if $suflen > $maxsuflen; } - $te = $test; - chop($te); - print "$te" . '.' x (18 - length($te)); - if ($sharpbang) { - -x $test || (print "isn't executable.\n"); - open(RESULTS,"./$test |") || (print "can't run.\n"); - } else { - open(SCRIPT,"$test") || die "Can't run $test.\n"; + # + 3 : we want three dots between the test name and the "ok" + $dotdotdot = $maxlen + 3 - $maxsuflen; + while ($test = shift @tests) { + + if ( $infinite{$test} && $type eq 'compile' ) { + print STDERR "$test creates infinite loop! Skipping.\n"; + next; + } + if ($test =~ /^$/) { + next; + } + if ($type eq 'deparse') { + if ($test eq "comp/redef.t") { + # Redefinition happens at compile time + next; + } + elsif ($test eq "lib/switch.t") { + # B::Deparse doesn't support source filtering + next; + } + } + $te = $test; + chop($te); + print "$te" . '.' x ($dotdotdot - length($te)); + + $test = $OVER{$test} if exists $OVER{$test}; + + open(SCRIPT,"<$test") or die "Can't run $test.\n"; $_ =