X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=vms%2Ftest.com;h=372ed74a22227213aeea2aa420607d1b87420652;hb=7dc9aaa56b11c3e04f31eb9de23451166e23126f;hp=0e507dd27401ee51d3fd35d596f2c0cec706bda5;hpb=103a9d1588db80145c6682742c60a9b743493535;p=p5sagit%2Fp5-mst-13.2.git diff --git a/vms/test.com b/vms/test.com index 0e507dd..372ed74 100644 --- a/vms/test.com +++ b/vms/test.com @@ -1,7 +1,7 @@ $! Test.Com - DCL driver for perl5 regression tests $! $! Version 1.1 4-Dec-1995 -$! Charles Bailey bailey@genetics.upenn.edu +$! Charles Bailey bailey@newman.upenn.edu $ $! A little basic setup $ On Error Then Goto wrapup @@ -19,7 +19,7 @@ $ Write Sys$Error "Can't find test directory" $ Exit 44 $ EndIf $ EndIf -$ Set Message /Facility/Severity/Identification/Text +$ Set Message /NoFacility/NoSeverity/NoIdentification/NoText $ $ exe = ".Exe" $ If p1.nes."" Then exe = p1 @@ -32,12 +32,24 @@ $ Write Sys$Error "Descrip.MMS or used the AXE=1 macro in the MM[SK] command $ 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. +$! +$! Pick up a copy of vmspipe.com to use for the tests +$ If F$Search("VMSPIPE.COM").nes."" then Delete/Log/Noconfirm VMSPIPE.COM;* +$ Copy/Log/NoConfirm [-]VMSPIPE.COM [] +$! $! Make the environment look a little friendlier to tests which assume Unix -$ cat = "Type" +$ cat == "Type" $ Macro/NoDebug/NoList/Object=Echo.Obj Sys$Input .title echo .psect data,wrt,noexe @@ -78,18 +90,20 @@ $ Macro/NoDebug/NoList/Object=Echo.Obj Sys$Input movl #1,r0 ret .end echo +$ If F$Search("Echo.Exe").nes."" Then Delete/Log/NoConfirm Echo.Exe;* $ 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 $ Show Process/Accounting $ testdir = "Directory/NoHead/NoTrail/Column=1" -$ Define/User Perlshr Sys$Disk:[-]PerlShr'exe' -$ MCR Sys$Disk:[]Perl. "-I[-.lib]" - "''p2'" "''p3'" "''p4'" "''p5'" "''p6'" +$ PerlShr_filespec = f$parse("Sys$Disk:[-]''dbg'PerlShr''exe'") +$ Define 'dbg'Perlshr 'PerlShr_filespec' +$ 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 +# $RCSfile: test.com,v $$Revision: 1.1 $$Date: 2001/11/07 06:58:50 $ +# 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. @@ -98,26 +112,28 @@ $ Deck/Dollar=$$END-OF-TEST$$ # 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; +use File::Spec; @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_sel.t', 'io_sock.t', - 'ndbm.t','odbm.t','open2.t','open3.t', 'ph.t', 'posix.t'); +@ioexcl=('dup.t'); +@libexcl=('io_dup.t', 'io_pipe.t', 'io_poll.t', 'io_sel.t', + 'io_sock.t', 'io_unix.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'); +@opexcl=('die_exit.t','exec.t','groups.t','magic.t','stat.t'); @exclist=(@compexcl,@ioexcl,@libexcl,@opexcl); foreach $file (@exclist) { $skip{$file}++; } $| = 1; +# Let tests know they're running in the perl core. Useful for modules +# which live dual lives on CPAN. +$ENV{PERL_CORE} = 1; + @ARGV = grep($_,@ARGV); # remove empty elements due to "''p1'" syntax if (lc($ARGV[0]) eq '-v') { @@ -128,8 +144,9 @@ if (lc($ARGV[0]) eq '-v') { chdir 't' if -f 't/TEST'; if ($ARGV[0] eq '') { - foreach (<[.*]*.t>) { - s/.*[\[.]t./[./; + foreach (<[-.ext...]*.t>, <[-.lib...]*.t>, <[.*]*.t>) { + $_ = File::Spec->abs2rel($_); + s/\[([a-z]+)/[.$1/; # hmm, abs2rel doesn't do subdirs of the cwd ($fname = $_) =~ s/.*\]//; if ($skip{"\L$fname"}) { push(@skipped,$_); } else { push(@ARGV,$_); } @@ -151,7 +168,7 @@ while ($test = shift) { } $te = $test; chop($te); - $te .= '.' x (24 - length($te)); + $te .= '.' x (40 - length($te)); open(script,"$test") || die "Can't run $test.\n"; $_ =