Commit | Line | Data |
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 |
52 | $ DeAssign sys |
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 |
67 | use Config; |
cd4070af |
68 | use 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 |
78 | if (lc($ARGV[0]) eq '-v') { |
a0d0e21e |
79 | $verbose = 1; |
34b5aed4 |
80 | shift; |
81 | } |
a0d0e21e |
82 | |
83 | chdir 't' if -f 't/TEST'; |
84 | |
85 | if ($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; |
98 | while ($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 | |
192 | if ($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 |
217 | print 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 |