This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
a71a93435601d0df8d8e4102503df22d93abbdbf
[perl5.git] / t / op / readline.t
1 #!./perl
2
3 BEGIN {
4     chdir 't';
5     @INC = '../lib';
6     require './test.pl';
7 }
8
9 plan tests => 18;
10
11 # [perl #19566]: sv_gets writes directly to its argument via
12 # TARG. Test that we respect SvREADONLY.
13 eval { for (\2) { $_ = <FH> } };
14 like($@, 'Modification of a read-only value attempted', '[perl #19566]');
15
16 # [perl #21628]
17 {
18   my $file = tempfile();
19   open A,'+>',$file; $a = 3;
20   is($a .= <A>, 3, '#21628 - $a .= <A> , A eof');
21   close A; $a = 4;
22   is($a .= <A>, 4, '#21628 - $a .= <A> , A closed');
23 }
24
25 # [perl #21614]: 82 is chosen to exceed the length for sv_grow in
26 # do_readline (80)
27 foreach my $k (1, 82) {
28   my $result
29     = runperl (stdin => '', stderr => 1,
30               prog => "\$x = q(k) x $k; \$a{\$x} = qw(v); \$_ = <> foreach keys %a; print qw(end)",
31               );
32   $result =~ s/\n\z// if $^O eq 'VMS';
33   is ($result, "end", '[perl #21614] for length ' . length('k' x $k));
34 }
35
36
37 foreach my $k (1, 21) {
38   my $result
39     = runperl (stdin => ' rules', stderr => 1,
40               prog => "\$x = q(perl) x $k; \$a{\$x} = q(v); foreach (keys %a) {\$_ .= <>; print}",
41               );
42   $result =~ s/\n\z// if $^O eq 'VMS';
43   is ($result, ('perl' x $k) . " rules", 'rcatline to shared sv for length ' . length('perl' x $k));
44 }
45
46 foreach my $l (1, 82) {
47   my $k = $l;
48   $k = 'k' x $k;
49   my $copy = $k;
50   $k = <DATA>;
51   is ($k, "moo\n", 'catline to COW sv for length ' . length $copy);
52 }
53
54
55 foreach my $l (1, 21) {
56   my $k = $l;
57   $k = 'perl' x $k;
58   my $perl = $k;
59   $k .= <DATA>;
60   is ($k, "$perl rules\n", 'rcatline to COW sv for length ' . length $perl);
61 }
62
63 use strict;
64 use File::Spec;
65
66 open F, File::Spec->curdir and sysread F, $_, 1;
67 my $err = $! + 0;
68 close F;
69
70 SKIP: {
71   skip "you can read directories as plain files", 2 unless( $err );
72
73   $!=0;
74   open F, File::Spec->curdir and $_=<F>;
75   ok( $!==$err && !defined($_) => 'readline( DIRECTORY )' );
76   close F;
77
78   $!=0;
79   { local $/;
80     open F, File::Spec->curdir and $_=<F>;
81     ok( $!==$err && !defined($_) => 'readline( DIRECTORY ) slurp mode' );
82     close F;
83   }
84 }
85
86 fresh_perl_is('BEGIN{<>}', '',
87               { switches => ['-w'], stdin => '', stderr => 1 },
88               'No ARGVOUT used only once warning');
89
90 fresh_perl_is('print readline', 'foo',
91               { switches => ['-w'], stdin => 'foo', stderr => 1 },
92               'readline() defaults to *ARGV');
93
94 my $obj = bless [];
95 $obj .= <DATA>;
96 like($obj, qr/main=ARRAY.*world/, 'rcatline and refs');
97
98 # bug #38631
99 require Tie::Scalar;
100 tie our $one, 'Tie::StdScalar', "A: ";
101 tie our $two, 'Tie::StdScalar', "B: ";
102 my $junk = $one;
103 $one .= <DATA>;
104 $two .= <DATA>;
105 is( $one, "A: One\n", "rcatline works with tied scalars" );
106 is( $two, "B: Two\n", "rcatline works with tied scalars" );
107
108 __DATA__
109 moo
110 moo
111  rules
112  rules
113 world
114 One
115 Two