diff options
author | Dave Mitchell <davem@fdisolutions.com> | 2004-03-11 14:52:58 +0000 |
---|---|---|
committer | Dave Mitchell <davem@fdisolutions.com> | 2004-03-11 14:52:58 +0000 |
commit | 68ba3c2c674c6fecf165cdd3b5e4da501410ba1a (patch) | |
tree | 88e641ea2152d36f15bfd59cbe472f712cae23b2 /t | |
parent | d0c3e6d694ba2b6651c767fbceed20be69dd8594 (diff) | |
download | perl-68ba3c2c674c6fecf165cdd3b5e4da501410ba1a.tar.gz |
make op/write.t work better under stdio by running the subtests
in the child process rather than the parent.
p4raw-id: //depot/perl@22485
Diffstat (limited to 't')
-rwxr-xr-x | t/op/write.t | 50 |
1 files changed, 39 insertions, 11 deletions
diff --git a/t/op/write.t b/t/op/write.t index 9f0e66b519..59fe268f59 100755 --- a/t/op/write.t +++ b/t/op/write.t @@ -58,7 +58,7 @@ for my $tref ( @NumTests ){ my $bas_tests = 20; # number of tests in section 3 -my $hmb_tests = 36; +my $hmb_tests = 37; printf "1..%d\n", $bas_tests + $num_tests + $hmb_tests; @@ -497,7 +497,7 @@ for my $tref ( @NumTests ){ : $writeres eq $expected; print $ok - ? "ok $nt\n" + ? "ok $nt - $writefmt\n" : "not ok $nt\n# f=[$writefmt] exp=[$expected] got=[$writeres]\n"; } } @@ -552,6 +552,7 @@ $= = 10; $test++; } select $oldfh; +close STDOUT_DUP; $^ = "STDOUT_TOP"; $= = 7; # Page length @@ -561,19 +562,46 @@ my $tm = 1; # Top margin (empty lines before first output) my $bm = 2; # Bottom marging (empty lines between last text and footer) my $lm = 4; # Left margin (indent in spaces) -select ((select (STDOUT), $| = 1)[0]); -if ($lm > 0 and !open STDOUT, "|-") { # Left margin (in this test ALWAYS set) - select ((select (STDOUT), $| = 1)[0]); +# ----------------------------------------------------------------------- +# +# execute the rest of the script in a child process. The parent reads the +# output from the child and compares it with <DATA>. + +my @data = <DATA>; + +select ((select (STDOUT), $| = 1)[0]); # flush STDOUT + +my $opened = open FROM_CHILD, "-|"; +unless (defined $opened) { + print "not ok $test - open gave $!\n"; exit 0; +} + +if ($opened) { + # in parent here + + print "ok $test - open\n"; $test++; my $s = " " x $lm; - while (<STDIN>) { + while (<FROM_CHILD>) { + unless (@data) { + print "not ok $test - too much output\n"; + exit; + } s/^/$s/; - print + ($_ eq <DATA> ? "" : "not "), "ok ", $test++, "\n"; + my $exp = shift @data; + print + ($_ eq $exp ? "" : "not "), "ok ", $test++, " \n"; + if ($_ ne $exp) { + s/\n/\\n/g for $_, $exp; + print "#expected: $exp\n#got: $_\n"; } - close STDIN; - print + (<DATA>?"not ":""), "ok ", $test++, "\n"; - close STDOUT; - exit; } + close FROM_CHILD; + print + (@data?"not ":""), "ok ", $test++, " - too litle output\n"; + exit; +} + +# in child here + + select ((select (STDOUT), $| = 1)[0]); $tm = "\n" x $tm; $= -= $bm + 1; # count one for the trailing "----" my $lastmin = 0; |