Update Changes.
[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$!
a0d0e21e 51$! And do it
09b7f37c 52$ Show Process/Accounting
e518068a 53$ testdir = "Directory/NoHead/NoTrail/Column=1"
746380c8 54$ PerlShr_filespec = f$parse("Sys$Disk:[-]''dbg'PerlShr''exe'")
55$ Define 'dbg'Perlshr 'PerlShr_filespec'
b6345914 56$ if f$mode() .nes. "INTERACTIVE" then Define PERL_SKIP_TTY_TEST 1
3eeba6fb 57$ MCR Sys$Disk:[]Perl. "-I[-.lib]" - "''p3'" "''p4'" "''p5'" "''p6'"
a0d0e21e 58$ Deck/Dollar=$$END-OF-TEST$$
a0d0e21e 59#
b6345914 60# The bulk of the below code is scheduled for deletion. test.com
61# will shortly use t/TEST.
62#
a0d0e21e 63
71be2cbc 64use Config;
cd4070af 65use File::Spec;
71be2cbc 66
a0d0e21e 67$| = 1;
68
60e23f2f 69# Let tests know they're running in the perl core. Useful for modules
70# which live dual lives on CPAN.
71$ENV{PERL_CORE} = 1;
72
34b5aed4 73@ARGV = grep($_,@ARGV); # remove empty elements due to "''p1'" syntax
74
61bb5906 75if (lc($ARGV[0]) eq '-v') {
a0d0e21e 76 $verbose = 1;
34b5aed4 77 shift;
78}
a0d0e21e 79
80chdir 't' if -f 't/TEST';
81
82if ($ARGV[0] eq '') {
91af766a 83 foreach (<[.*]*.t>, <[-.ext...]*.t>, <[-.lib...]*.t>) {
cd4070af 84 $_ = File::Spec->abs2rel($_);
85 s/\[([a-z]+)/[.$1/; # hmm, abs2rel doesn't do subdirs of the cwd
34b5aed4 86 ($fname = $_) =~ s/.*\]//;
de5a37b2 87 push(@ARGV,$_);
a0d0e21e 88 }
89}
90
a0d0e21e 91$bad = 0;
92$good = 0;
d9ae6319 93$extra_skip = 0;
a0d0e21e 94$total = @ARGV;
95while ($test = shift) {
96 if ($test =~ /^$/) {
97 next;
98 }
99 $te = $test;
100 chop($te);
cd4070af 101 $te .= '.' x (40 - length($te));
a0d0e21e 102 open(script,"$test") || die "Can't run $test.\n";
103 $_ = <script>;
104 close(script);
19b5e0e6 105 if (/#!.*\bperl.*-\w*([tT])/) {
106 $switch = qq{"-$1"};
a0d0e21e 107 } else {
108 $switch = '';
109 }
9428117f 110 open(results,"\$ MCR Sys\$Disk:[]Perl. \"-I[-.lib]\" $switch $test 2>&1|") || (print "can't run.\n");
a0d0e21e 111 $ok = 0;
112 $next = 0;
3eeba6fb 113 $pending_not = 0;
a0d0e21e 114 while (<results>) {
115 if ($verbose) {
34b5aed4 116 print "$te$_";
117 $te = '';
a0d0e21e 118 }
119 unless (/^#/) {
6c750130 120 if (/^1\.\.([0-9]+)( todo ([\d ]+))?/) {
a0d0e21e 121 $max = $1;
6c750130 122 %todo = map { $_ => 1 } split / /, $3 if $3;
a0d0e21e 123 $totmax += $max;
124 $files += 1;
125 $next = 1;
126 $ok = 1;
127 } else {
6c750130 128 # our 'echo' substitute produces one more \n than Unix'
129 next if /^\s*$/;
130
131
e617780b 132 if (/^(not )?ok (\d+)[^#]*(\s*#.*)?/ &&
6c750130 133 $2 == $next)
134 {
135 my($not, $num, $extra) = ($1, $2, $3);
136 my($istodo) = $extra =~ /^\s*#\s*TODO/ if $extra;
137 $istodo = 1 if $todo{$num};
138
139 if( $not && !$istodo ) {
140 $ok = 0;
141 $next = $num;
142 last;
143 }
144 elsif( $pending_not ) {
145 $next = $num;
146 $ok = 0;
147 }
148 else {
149 $next = $next + 1;
150 }
151 }
152 elsif(/^not $/) {
153 # VMS has this problem. It sometimes adds newlines
154 # between prints. This sometimes means you get
155 # "not \nok 42"
156 $pending_not = 1;
157 }
158 elsif (/^Bail out!\s*(.*)/i) { # magic words
159 die "FAILED--Further testing stopped" . ($1 ? ": $1\n" : ".\n");
a0d0e21e 160 }
6c750130 161 else {
162 $ok = 0;
163 }
164
a0d0e21e 165 }
166 }
167 }
168 $next = $next - 1;
169 if ($ok && $next == $max) {
271404a7 170 if ($max) {
171 print "${te}ok\n";
172 $good = $good + 1;
173 } else {
174 print "${te}skipping test on this platform\n";
175 $files -= 1;
d9ae6319 176 $extra_skip = $extra_skip + 1;
271404a7 177 }
a0d0e21e 178 } else {
179 $next += 1;
34b5aed4 180 print "${te}FAILED on test $next\n";
a0d0e21e 181 $bad = $bad + 1;
182 $_ = $test;
183 if (/^base/) {
184 die "Failed a basic test--cannot continue.\n";
185 }
186 }
187}
188
189if ($bad == 0) {
190 if ($ok) {
191 print "All tests successful.\n";
192 } else {
193 die "FAILED--no tests were run for some reason.\n";
194 }
195} else {
d9ae6319 196 # $pct = sprintf("%.2f", $good / $total * 100);
197 $gtotal = $total - $extra_skip;
198 if ($gtotal <= 0) { $gtotal = $total; }
199 $pct = sprintf("%.2f", $good / $gtotal * 100);
a0d0e21e 200 if ($bad == 1) {
201 warn "Failed 1 test, $pct% okay.\n";
d9ae6319 202 } else {
203 if ($extra_skip > 0) {
204 warn "Total tests: $total, Passed $good, Skipped $extra_skip.\n";
205 warn "Failed $bad/$gtotal tests, $pct% okay.\n";
206 }
207 else {
208 warn "Total tests: $total, Passed $good.\n";
209 warn "Failed $bad/$gtotal tests, $pct% okay.\n";
210 }
a0d0e21e 211 }
212}
213($user,$sys,$cuser,$csys) = times;
c04215f0 214print sprintf("u=%g s=%g cu=%g cs=%g scripts=%d tests=%d\n",
a0d0e21e 215 $user,$sys,$cuser,$csys,$files,$totmax);
216$$END-OF-TEST$$
217$ wrapup:
23724483 218$ deassign 'dbg'Perlshr
09b7f37c 219$ Show Process/Accounting
e518068a 220$ Set Default &olddef
84902520 221$ Set Message 'oldmsg'
a0d0e21e 222$ Exit