"foo bar"->()
[p5sagit/p5-mst-13.2.git] / vms / test.com
CommitLineData
a0d0e21e 1$! Test.Com - DCL driver for perl5 regression tests
2$!
e518068a 3$! Version 1.1 4-Dec-1995
bd3fa61c 4$! Charles Bailey bailey@newman.upenn.edu
d9ae6319 5$!
a0d0e21e 6$! A little basic setup
7$ On Error Then Goto wrapup
e518068a 8$ olddef = F$Environment("Default")
84902520 9$ oldmsg = F$Environment("Message")
e518068a 10$ If F$Search("t.dir").nes.""
11$ Then
12$ Set Default [.t]
13$ Else
14$ If F$TrnLNm("Perl_Root").nes.""
15$ Then
16$ Set Default Perl_Root:[t]
17$ Else
18$ Write Sys$Error "Can't find test directory"
19$ Exit 44
20$ EndIf
21$ EndIf
93d6612c 22$ Set Message /NoFacility/NoSeverity/NoIdentification/NoText
d9ae6319 23$!
491527d0 24$ exe = ".Exe"
25$ If p1.nes."" Then exe = p1
26$ If F$Extract(0,1,exe) .nes. "."
27$ Then
28$ Write Sys$Error ""
29$ Write Sys$Error "The first parameter passed to Test.Com must be the file type used for the"
30$ Write Sys$Error "images produced when you built Perl (i.e. "".Exe"", unless you edited"
31$ Write Sys$Error "Descrip.MMS or used the AXE=1 macro in the MM[SK] command line."
32$ Write Sys$Error ""
33$ Exit 44
34$ EndIf
3eeba6fb 35$!
36$! "debug" perl if second parameter is nonblank
37$!
38$ dbg = ""
39$ ndbg = ""
40$ if p2.nes."" then dbg = "dbg"
41$ if p2.nes."" then ndbg = "ndbg"
42$!
a0d0e21e 43$! Pick up a copy of perl to use for the tests
8713643e 44$ If F$Search("Perl.").nes."" Then Delete/Log/NoConfirm Perl.;*
3eeba6fb 45$ Copy/Log/NoConfirm [-]'ndbg'Perl'exe' []Perl.
59d8d783 46$!
47$! Pick up a copy of vmspipe.com to use for the tests
48$ If F$Search("VMSPIPE.COM").nes."" then Delete/Log/Noconfirm VMSPIPE.COM;*
49$ Copy/Log/NoConfirm [-]VMSPIPE.COM []
50$!
1e9d704e 51$! This may be set for the C compiler in descrip.mms, but it confuses the File::Find tests
1f5d76b2 52$ if f$trnlnm("sys") .nes. "" then DeAssign sys
1e9d704e 53$!
a0d0e21e 54$! And do it
09b7f37c 55$ Show Process/Accounting
e518068a 56$ testdir = "Directory/NoHead/NoTrail/Column=1"
746380c8 57$ PerlShr_filespec = f$parse("Sys$Disk:[-]''dbg'PerlShr''exe'")
58$ Define 'dbg'Perlshr 'PerlShr_filespec'
b6345914 59$ if f$mode() .nes. "INTERACTIVE" then Define PERL_SKIP_TTY_TEST 1
3eeba6fb 60$ MCR Sys$Disk:[]Perl. "-I[-.lib]" - "''p3'" "''p4'" "''p5'" "''p6'"
a0d0e21e 61$ Deck/Dollar=$$END-OF-TEST$$
a0d0e21e 62#
b6345914 63# The bulk of the below code is scheduled for deletion. test.com
64# will shortly use t/TEST.
65#
a0d0e21e 66
71be2cbc 67use Config;
cd4070af 68use File::Spec;
71be2cbc 69
a0d0e21e 70$| = 1;
71
60e23f2f 72# Let tests know they're running in the perl core. Useful for modules
73# which live dual lives on CPAN.
74$ENV{PERL_CORE} = 1;
75
34b5aed4 76@ARGV = grep($_,@ARGV); # remove empty elements due to "''p1'" syntax
77
61bb5906 78if (lc($ARGV[0]) eq '-v') {
a0d0e21e 79 $verbose = 1;
34b5aed4 80 shift;
81}
a0d0e21e 82
83chdir 't' if -f 't/TEST';
84
85if ($ARGV[0] eq '') {
91af766a 86 foreach (<[.*]*.t>, <[-.ext...]*.t>, <[-.lib...]*.t>) {
cd4070af 87 $_ = File::Spec->abs2rel($_);
88 s/\[([a-z]+)/[.$1/; # hmm, abs2rel doesn't do subdirs of the cwd
34b5aed4 89 ($fname = $_) =~ s/.*\]//;
de5a37b2 90 push(@ARGV,$_);
a0d0e21e 91 }
92}
93
a0d0e21e 94$bad = 0;
95$good = 0;
d9ae6319 96$extra_skip = 0;
a0d0e21e 97$total = @ARGV;
98while ($test = shift) {
99 if ($test =~ /^$/) {
100 next;
101 }
102 $te = $test;
103 chop($te);
cd4070af 104 $te .= '.' x (40 - length($te));
a0d0e21e 105 open(script,"$test") || die "Can't run $test.\n";
106 $_ = <script>;
107 close(script);
19b5e0e6 108 if (/#!.*\bperl.*-\w*([tT])/) {
109 $switch = qq{"-$1"};
a0d0e21e 110 } else {
111 $switch = '';
112 }
9428117f 113 open(results,"\$ MCR Sys\$Disk:[]Perl. \"-I[-.lib]\" $switch $test 2>&1|") || (print "can't run.\n");
a0d0e21e 114 $ok = 0;
115 $next = 0;
3eeba6fb 116 $pending_not = 0;
a0d0e21e 117 while (<results>) {
118 if ($verbose) {
34b5aed4 119 print "$te$_";
120 $te = '';
a0d0e21e 121 }
122 unless (/^#/) {
6c750130 123 if (/^1\.\.([0-9]+)( todo ([\d ]+))?/) {
a0d0e21e 124 $max = $1;
6c750130 125 %todo = map { $_ => 1 } split / /, $3 if $3;
a0d0e21e 126 $totmax += $max;
127 $files += 1;
128 $next = 1;
129 $ok = 1;
130 } else {
6c750130 131 # our 'echo' substitute produces one more \n than Unix'
132 next if /^\s*$/;
133
134
e617780b 135 if (/^(not )?ok (\d+)[^#]*(\s*#.*)?/ &&
6c750130 136 $2 == $next)
137 {
138 my($not, $num, $extra) = ($1, $2, $3);
139 my($istodo) = $extra =~ /^\s*#\s*TODO/ if $extra;
140 $istodo = 1 if $todo{$num};
141
142 if( $not && !$istodo ) {
143 $ok = 0;
144 $next = $num;
145 last;
146 }
147 elsif( $pending_not ) {
148 $next = $num;
149 $ok = 0;
150 }
151 else {
152 $next = $next + 1;
153 }
154 }
155 elsif(/^not $/) {
156 # VMS has this problem. It sometimes adds newlines
157 # between prints. This sometimes means you get
158 # "not \nok 42"
159 $pending_not = 1;
160 }
161 elsif (/^Bail out!\s*(.*)/i) { # magic words
162 die "FAILED--Further testing stopped" . ($1 ? ": $1\n" : ".\n");
a0d0e21e 163 }
6c750130 164 else {
165 $ok = 0;
166 }
167
a0d0e21e 168 }
169 }
170 }
171 $next = $next - 1;
172 if ($ok && $next == $max) {
271404a7 173 if ($max) {
174 print "${te}ok\n";
175 $good = $good + 1;
176 } else {
177 print "${te}skipping test on this platform\n";
178 $files -= 1;
d9ae6319 179 $extra_skip = $extra_skip + 1;
271404a7 180 }
a0d0e21e 181 } else {
182 $next += 1;
34b5aed4 183 print "${te}FAILED on test $next\n";
a0d0e21e 184 $bad = $bad + 1;
185 $_ = $test;
186 if (/^base/) {
187 die "Failed a basic test--cannot continue.\n";
188 }
189 }
190}
191
192if ($bad == 0) {
193 if ($ok) {
194 print "All tests successful.\n";
195 } else {
196 die "FAILED--no tests were run for some reason.\n";
197 }
198} else {
d9ae6319 199 # $pct = sprintf("%.2f", $good / $total * 100);
200 $gtotal = $total - $extra_skip;
201 if ($gtotal <= 0) { $gtotal = $total; }
202 $pct = sprintf("%.2f", $good / $gtotal * 100);
a0d0e21e 203 if ($bad == 1) {
204 warn "Failed 1 test, $pct% okay.\n";
d9ae6319 205 } else {
206 if ($extra_skip > 0) {
207 warn "Total tests: $total, Passed $good, Skipped $extra_skip.\n";
208 warn "Failed $bad/$gtotal tests, $pct% okay.\n";
209 }
210 else {
211 warn "Total tests: $total, Passed $good.\n";
212 warn "Failed $bad/$gtotal tests, $pct% okay.\n";
213 }
a0d0e21e 214 }
215}
216($user,$sys,$cuser,$csys) = times;
c04215f0 217print sprintf("u=%g s=%g cu=%g cs=%g scripts=%d tests=%d\n",
a0d0e21e 218 $user,$sys,$cuser,$csys,$files,$totmax);
219$$END-OF-TEST$$
220$ wrapup:
23724483 221$ deassign 'dbg'Perlshr
09b7f37c 222$ Show Process/Accounting
e518068a 223$ Set Default &olddef
84902520 224$ Set Message 'oldmsg'
a0d0e21e 225$ Exit