1998-09-09 07:00:04 +00:00
|
|
|
#!./perl
|
|
|
|
|
|
|
|
BEGIN {
|
|
|
|
chdir 't' if -d 't';
|
2000-06-25 11:04:01 +00:00
|
|
|
unshift @INC, '../lib';
|
1998-09-09 07:00:04 +00:00
|
|
|
$ENV{PERL5LIB} = '../lib';
|
|
|
|
}
|
|
|
|
|
|
|
|
$| = 1;
|
|
|
|
|
|
|
|
my $Is_VMS = $^O eq 'VMS';
|
|
|
|
my $Is_MSWin32 = $^O eq 'MSWin32';
|
|
|
|
my $tmpfile = "tmp0000";
|
|
|
|
my $i = 0 ;
|
|
|
|
1 while -f ++$tmpfile;
|
|
|
|
END { if ($tmpfile) { 1 while unlink $tmpfile; } }
|
|
|
|
|
|
|
|
my @prgs = () ;
|
|
|
|
|
|
|
|
foreach (sort glob("pragma/strict-*")) {
|
|
|
|
|
|
|
|
next if /(~|\.orig)$/;
|
|
|
|
|
|
|
|
open F, "<$_" or die "Cannot open $_: $!\n" ;
|
|
|
|
while (<F>) {
|
|
|
|
last if /^__END__/ ;
|
|
|
|
}
|
|
|
|
|
|
|
|
{
|
|
|
|
local $/ = undef;
|
|
|
|
@prgs = (@prgs, split "\n########\n", <F>) ;
|
|
|
|
}
|
|
|
|
close F ;
|
|
|
|
}
|
|
|
|
|
|
|
|
undef $/;
|
|
|
|
|
|
|
|
print "1..", scalar @prgs, "\n";
|
|
|
|
|
|
|
|
|
|
|
|
for (@prgs){
|
|
|
|
my $switch = "";
|
|
|
|
my @temps = () ;
|
|
|
|
if (s/^\s*-\w+//){
|
|
|
|
$switch = $&;
|
|
|
|
}
|
|
|
|
my($prog,$expected) = split(/\nEXPECT\n/, $_);
|
|
|
|
if ( $prog =~ /--FILE--/) {
|
|
|
|
my(@files) = split(/\n--FILE--\s*([^\s\n]*)\s*\n/, $prog) ;
|
|
|
|
shift @files ;
|
|
|
|
die "Internal error test $i didn't split into pairs, got " .
|
|
|
|
scalar(@files) . "[" . join("%%%%", @files) ."]\n"
|
|
|
|
if @files % 2 ;
|
|
|
|
while (@files > 2) {
|
|
|
|
my $filename = shift @files ;
|
|
|
|
my $code = shift @files ;
|
|
|
|
push @temps, $filename ;
|
|
|
|
open F, ">$filename" or die "Cannot open $filename: $!\n" ;
|
|
|
|
print F $code ;
|
|
|
|
close F ;
|
|
|
|
}
|
|
|
|
shift @files ;
|
|
|
|
$prog = shift @files ;
|
|
|
|
}
|
|
|
|
open TEST, ">$tmpfile";
|
|
|
|
print TEST $prog,"\n";
|
|
|
|
close TEST;
|
2000-06-25 11:04:01 +00:00
|
|
|
my $results = $Is_MSWin32 ?
|
1998-09-09 07:00:04 +00:00
|
|
|
`.\\perl -I../lib $switch $tmpfile 2>&1` :
|
2000-06-25 11:04:01 +00:00
|
|
|
`./perl $switch $tmpfile 2>&1`;
|
1998-09-09 07:00:04 +00:00
|
|
|
my $status = $?;
|
|
|
|
$results =~ s/\n+$//;
|
|
|
|
# allow expected output to be written as if $prog is on STDIN
|
|
|
|
$results =~ s/tmp\d+/-/g;
|
|
|
|
$results =~ s/\n%[A-Z]+-[SIWEF]-.*$// if $Is_VMS; # clip off DCL status msg
|
|
|
|
$expected =~ s/\n+$//;
|
|
|
|
my $prefix = ($results =~ s/^PREFIX\n//) ;
|
|
|
|
if ( $results =~ s/^SKIPPED\n//) {
|
|
|
|
print "$results\n" ;
|
|
|
|
}
|
|
|
|
elsif (($prefix and $results !~ /^\Q$expected/) or
|
|
|
|
(!$prefix and $results ne $expected)){
|
|
|
|
print STDERR "PROG: $switch\n$prog\n";
|
|
|
|
print STDERR "EXPECTED:\n$expected\n";
|
|
|
|
print STDERR "GOT:\n$results\n";
|
|
|
|
print "not ";
|
|
|
|
}
|
|
|
|
print "ok ", ++$i, "\n";
|
|
|
|
foreach (@temps)
|
|
|
|
{ unlink $_ if $_ }
|
|
|
|
}
|