VMS-specific follow-up to tempfile name changes in 34182, plus
[p5sagit/p5-mst-13.2.git] / t / io / dup.t
1 #!./perl
2
3 BEGIN {
4     chdir 't' if -d 't';
5     @INC = qw(. ../lib);
6     require "./test.pl";
7 }
8
9 use Config;
10 no warnings 'once';
11
12 my $test = 1;
13 my $tests_needing_perlio = 17;
14 plan(12 + $tests_needing_perlio);
15 print "ok 1\n";
16
17 open(DUPOUT,">&STDOUT");
18 open(DUPERR,">&STDERR");
19
20 my $tempfile = tempfile();
21
22 open(STDOUT,">$tempfile")  || die "Can't open stdout";
23 open(STDERR,">&STDOUT") || die "Can't open stderr";
24
25 select(STDERR); $| = 1;
26 select(STDOUT); $| = 1;
27
28 print STDOUT "ok 2\n";
29 print STDERR "ok 3\n";
30
31 # Since some systems don't have echo, we use Perl.
32 $echo = qq{$^X -le "print q(ok %d)"};
33
34 $cmd = sprintf $echo, 4;
35 print `$cmd`;
36
37 $cmd = sprintf "$echo 1>&2", 5;
38 $cmd = sprintf $echo, 5 if $^O eq 'MacOS';  # don't know if we can do this ...
39 print `$cmd`;
40
41 system sprintf $echo, 6;
42 if ($^O eq 'MacOS') {
43     system sprintf $echo, 7;
44 }
45 else {
46     system sprintf "$echo 1>&2", 7;
47 }
48
49 close(STDOUT) or die "Could not close: $!";
50 close(STDERR) or die "Could not close: $!";
51
52 open(STDOUT,">&DUPOUT") or die "Could not open: $!";
53 open(STDERR,">&DUPERR") or die "Could not open: $!";
54
55 if (($^O eq 'MSWin32') || ($^O eq 'NetWare')) { print `type $tempfile` }
56 elsif ($^O eq 'VMS')   { system "type $tempfile.;" } # TYPE defaults to .LIS when there is no extension
57 elsif ($^O eq 'MacOS') { system "catenate $tempfile" }
58 else                   { system "cat $tempfile" }
59
60 print STDOUT "ok 8\n";
61
62 open(F,">&",1) or die "Cannot dup to numeric 1: $!";
63 print F "ok 9\n";
64 close(F);
65
66 open(F,">&",'1') or die "Cannot dup to string '1': $!";
67 print F "ok 10\n";
68 close(F);
69
70 open(F,">&=",1) or die "Cannot dup to numeric 1: $!";
71 print F "ok 11\n";
72 close(F);
73
74 if ($Config{useperlio}) {
75     open(F,">&=",'1') or die "Cannot dup to string '1': $!";
76     print F "ok 12\n";
77     close(F);
78 } else {
79     open(F, ">&DUPOUT") or die "Cannot dup stdout back: $!";
80     print F "ok 12\n";
81     close(F);
82 }
83
84 # To get STDOUT back.
85 open(F, ">&DUPOUT") or die "Cannot dup stdout back: $!";
86
87 curr_test(13);
88
89 SKIP: {
90     skip("need perlio", $tests_needing_perlio) unless $Config{useperlio};
91     
92     ok(open(F, ">&", STDOUT));
93     isnt(fileno(F), fileno(STDOUT));
94     close F;
95
96     ok(open(F, "<&=STDIN")) or _diag $!;
97     is(fileno(F), fileno(STDIN));
98     close F;
99
100     ok(open(F, ">&=STDOUT"));
101     is(fileno(F), fileno(STDOUT));
102     close F;
103
104     ok(open(F, ">&=STDERR"));
105     is(fileno(F), fileno(STDERR));
106     close F;
107
108     open(G, ">$tempfile") or die;
109     my $g = fileno(G);
110
111     ok(open(F, ">&=$g"));
112     is(fileno(F), $g);
113     close F;
114
115     ok(open(F, ">&=G"));
116     is(fileno(F), $g);
117
118     print G "ggg\n";
119     print F "fff\n";
120
121     close G; # flush first
122     close F; # flush second
123
124     open(G, "<$tempfile") or die;
125     {
126         my $line;
127         $line = <G>; chomp $line; is($line, "ggg");
128         $line = <G>; chomp $line; is($line, "fff");
129     }
130     close G;
131
132     open UTFOUT, '>:utf8', $tempfile or die $!;
133     open UTFDUP, '>&UTFOUT' or die $!;
134     # some old greek saying.
135     my $message = "\x{03A0}\x{0391}\x{039D}\x{03A4}\x{0391} \x{03A1}\x{0395}\x{0399}\n";
136     print UTFOUT $message;
137     print UTFDUP $message;
138     binmode UTFDUP, ':utf8';
139     print UTFDUP $message;
140     close UTFOUT;
141     close UTFDUP;
142     open(UTFIN, "<:utf8", $tempfile) or die $!;
143     {
144         my $line;
145         $line = <UTFIN>; is($line, $message);
146         $line = <UTFIN>; is($line, $message);
147         $line = <UTFIN>; is($line, $message);
148     }
149     close UTFIN;
150
151 }