X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=vms%2Ftest.com;h=522904d7190f2bd52ee9e82903cfb5c523ba3a23;hb=9e29e5ff005da001be364f21377fa2a6364952d5;hp=a23245057f52bd9d0b53bd3ff63e2f5f676cde46;hpb=748a93069b3d16374a9859d1456065dd3ae11394;p=p5sagit%2Fp5-mst-13.2.git diff --git a/vms/test.com b/vms/test.com index a232450..522904d 100644 --- a/vms/test.com +++ b/vms/test.com @@ -1,25 +1,52 @@ $! Test.Com - DCL driver for perl5 regression tests $! -$! Version 1.0 30-Sep-1994 -$! Charles Bailey bailey@genetics.upenn.edu +$! Version 1.1 4-Dec-1995 +$! Charles Bailey bailey@newman.upenn.edu $ $! A little basic setup $ On Error Then Goto wrapup $ olddef = F$Environment("Default") -$ If F$TrnLNm("Perl_Root").nes."" +$ oldmsg = F$Environment("Message") +$ If F$Search("t.dir").nes."" $ Then -$ Set Default Perl_Root:[t] -$ Else $ Set Default [.t] +$ Else +$ If F$TrnLNm("Perl_Root").nes."" +$ Then +$ Set Default Perl_Root:[t] +$ Else +$ Write Sys$Error "Can't find test directory" +$ Exit 44 +$ EndIf $ EndIf +$ Set Message /NoFacility/NoSeverity/NoIdentification/NoText $ +$ exe = ".Exe" +$ If p1.nes."" Then exe = p1 +$ If F$Extract(0,1,exe) .nes. "." +$ Then +$ Write Sys$Error "" +$ Write Sys$Error "The first parameter passed to Test.Com must be the file type used for the" +$ Write Sys$Error "images produced when you built Perl (i.e. "".Exe"", unless you edited" +$ Write Sys$Error "Descrip.MMS or used the AXE=1 macro in the MM[SK] command line." +$ Write Sys$Error "" +$ Exit 44 +$ EndIf +$! +$! "debug" perl if second parameter is nonblank +$! +$ dbg = "" +$ ndbg = "" +$ if p2.nes."" then dbg = "dbg" +$ if p2.nes."" then ndbg = "ndbg" +$! $! Pick up a copy of perl to use for the tests -$ Delete/Log/NoConfirm Perl.;* -$ Copy/Log/NoConfirm [-]Perl.Exe []Perl. +$ If F$Search("Perl.").nes."" Then Delete/Log/NoConfirm Perl.;* +$ Copy/Log/NoConfirm [-]'ndbg'Perl'exe' []Perl. $ $! Make the environment look a little friendlier to tests which assume Unix -$ cat = "Type" -$ Macro/NoDebug/Object=Echo.Obj Sys$Input +$ cat == "Type" +$ Macro/NoDebug/NoList/Object=Echo.Obj Sys$Input .title echo .psect data,wrt,noexe dsc: @@ -59,43 +86,60 @@ $ Macro/NoDebug/Object=Echo.Obj Sys$Input movl #1,r0 ret .end echo -$ Link/NoTrace Echo.Obj; +$ Link/NoMap/NoTrace/Exe=Echo.Exe Echo.Obj; $ Delete/Log/NoConfirm Echo.Obj;* -$ echo = "$" + F$Parse("Echo.Exe") +$ echo == "$" + F$Parse("Echo.Exe") $ $! And do it -$ MCR Sys$Disk:[]Perl. +$ Show Process/Accounting +$ testdir = "Directory/NoHead/NoTrail/Column=1" +$ Define 'dbg'Perlshr Sys$Disk:[-]'dbg'PerlShr'exe' +$ MCR Sys$Disk:[]Perl. "-I[-.lib]" - "''p3'" "''p4'" "''p5'" "''p6'" $ Deck/Dollar=$$END-OF-TEST$$ # $RCSfile: TEST,v $$Revision: 4.1 $$Date: 92/08/07 18:27:00 $ -# Modified for VMS 30-Sep-1994 Charles Bailey bailey@genetics.upenn.edu +# Modified for VMS 30-Sep-1994 Charles Bailey bailey@newman.upenn.edu # # This is written in a peculiar style, since we're trying to avoid # most of the constructs we'll be testing for. # skip those tests we know will fail entirely or cause perl to hang bacause -# of Unixisms -@compexcl=('cpp.t','script.t'); -@ioexcl=('argv.t','dup.t','fs.t','inplace.t','pipe.t'); -@libexcl=('anydbm.t','db-btree.t','db-hash.t','db-recno.t', - 'gdbm.t','ndbm.t','odbm.t','sdbm.t','posix.t','soundex.t'); -@opexcl=('exec.t','fork.t','glob.t','magic.t','misc.t','stat.t'); +# of Unixisms in the tests. (The Perl operators being tested may work fine, +# but the tests may use other operators which don't.) +use Config; + +@compexcl=('cpp.t'); +@ioexcl=('argv.t','dup.t','fs.t','pipe.t'); +@libexcl=('db-btree.t','db-hash.t','db-recno.t', + 'gdbm.t','io_dup.t', 'io_pipe.t', 'io_poll.t', 'io_sel.t', + 'io_sock.t', 'io_unix.t', + 'ndbm.t','odbm.t','open2.t','open3.t', 'ph.t', 'posix.t'); + +# Note: POSIX is not part of basic build, but can be built +# separately if you're using DECC +# io_xs.t tests the new_tmpfile routine, which doesn't work with the +# VAXCRTL, since the file can't be stat()d, an Perl's do_open() +# insists on stat()ing a file descriptor before it'll use it. +push(@libexcl,'io_xs.t') if $Config{'vms_cc_type'} ne 'decc'; + +@opexcl=('die_exit.t','exec.t','fork.t','glob.t','groups.t','magic.t','misc.t','stat.t'); @exclist=(@compexcl,@ioexcl,@libexcl,@opexcl); foreach $file (@exclist) { $skip{$file}++; } $| = 1; -#if ($ARGV[0] eq '-v') { +@ARGV = grep($_,@ARGV); # remove empty elements due to "''p1'" syntax + +if (lc($ARGV[0]) eq '-v') { $verbose = 1; -# shift; -#} + shift; +} chdir 't' if -f 't/TEST'; if ($ARGV[0] eq '') { - @files = split(/[ \n]/, `\$ dir/col=1/nohead/notrail [...]*.t;`); - foreach (@files) { - $fname = $_; - $fname =~ s/.*\]([\w\$\-]+\.T);.*/$1/; + foreach (<[.*]*.t>) { + s/.*[\[.]t./[./; + ($fname = $_) =~ s/.*\]//; if ($skip{"\L$fname"}) { push(@skipped,$_); } else { push(@ARGV,$_); } } @@ -104,7 +148,7 @@ if ($ARGV[0] eq '') { if (@skipped) { print "The following tests were skipped because they rely extensively on\n"; print " Unixisms not compatible with the current version of perl for VMS:\n"; - print "\t",join("\n\t",@skipped); + print "\t",join("\n\t",@skipped),"\n\n"; } $bad = 0; @@ -116,21 +160,25 @@ while ($test = shift) { } $te = $test; chop($te); - print "$te" . '.' x (15 - length($te)) . "\n"; + $te .= '.' x (24 - length($te)); open(script,"$test") || die "Can't run $test.\n"; $_ =