1 | #!./perl
|
---|
2 |
|
---|
3 | # Checks if the parser behaves correctly in edge cases
|
---|
4 | # (including weird syntax errors)
|
---|
5 |
|
---|
6 | BEGIN {
|
---|
7 | chdir 't' if -d 't';
|
---|
8 | @INC = '../lib';
|
---|
9 | }
|
---|
10 |
|
---|
11 | require "./test.pl";
|
---|
12 | plan( tests => 53 );
|
---|
13 |
|
---|
14 | eval '%@x=0;';
|
---|
15 | like( $@, qr/^Can't modify hash dereference in repeat \(x\)/, '%@x=0' );
|
---|
16 |
|
---|
17 | # Bug 20010422.005
|
---|
18 | eval q{{s//${}/; //}};
|
---|
19 | like( $@, qr/syntax error/, 'syntax error, used to dump core' );
|
---|
20 |
|
---|
21 | # Bug 20010528.007
|
---|
22 | eval q/"\x{"/;
|
---|
23 | like( $@, qr/^Missing right brace on \\x/,
|
---|
24 | 'syntax error in string, used to dump core' );
|
---|
25 |
|
---|
26 | eval "a.b.c.d.e.f;sub";
|
---|
27 | like( $@, qr/^Illegal declaration of anonymous subroutine/,
|
---|
28 | 'found by Markov chain stress testing' );
|
---|
29 |
|
---|
30 | # Bug 20010831.001
|
---|
31 | eval '($a, b) = (1, 2);';
|
---|
32 | like( $@, qr/^Can't modify constant item in list assignment/,
|
---|
33 | 'bareword in list assignment' );
|
---|
34 |
|
---|
35 | eval 'tie FOO, "Foo";';
|
---|
36 | like( $@, qr/^Can't modify constant item in tie /,
|
---|
37 | 'tying a bareword causes a segfault in 5.6.1' );
|
---|
38 |
|
---|
39 | eval 'undef foo';
|
---|
40 | like( $@, qr/^Can't modify constant item in undef operator /,
|
---|
41 | 'undefing constant causes a segfault in 5.6.1 [ID 20010906.019]' );
|
---|
42 |
|
---|
43 | eval 'read($bla, FILE, 1);';
|
---|
44 | like( $@, qr/^Can't modify constant item in read /,
|
---|
45 | 'read($var, FILE, 1) segfaults on 5.6.1 [ID 20011025.054]' );
|
---|
46 |
|
---|
47 | # This used to dump core (bug #17920)
|
---|
48 | eval q{ sub { sub { f1(f2();); my($a,$b,$c) } } };
|
---|
49 | like( $@, qr/error/, 'lexical block discarded by yacc' );
|
---|
50 |
|
---|
51 | # bug #18573, used to corrupt memory
|
---|
52 | eval q{ "\c" };
|
---|
53 | like( $@, qr/^Missing control char name in \\c/, q("\c" string) );
|
---|
54 |
|
---|
55 | eval q{ qq(foo$) };
|
---|
56 | like( $@, qr/Final \$ should be \\\$ or \$name/, q($ at end of "" string) );
|
---|
57 |
|
---|
58 | # two tests for memory corruption problems in the said variables
|
---|
59 | # (used to dump core or produce strange results)
|
---|
60 |
|
---|
61 | is( "\Q\Q\Q\Q\Q\Q\Q\Q\Q\Q\Q\Q\Qa", "a", "PL_lex_casestack" );
|
---|
62 |
|
---|
63 | eval {
|
---|
64 | {{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{
|
---|
65 | {{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{
|
---|
66 | {{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{{
|
---|
67 | }}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}
|
---|
68 | }}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}
|
---|
69 | }}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}}
|
---|
70 | };
|
---|
71 | is( $@, '', 'PL_lex_brackstack' );
|
---|
72 |
|
---|
73 | {
|
---|
74 | # tests for bug #20716
|
---|
75 | undef $a;
|
---|
76 | undef @b;
|
---|
77 | my $a="A";
|
---|
78 | is("${a}{", "A{", "interpolation, qq//");
|
---|
79 | is("${a}[", "A[", "interpolation, qq//");
|
---|
80 | my @b=("B");
|
---|
81 | is("@{b}{", "B{", "interpolation, qq//");
|
---|
82 | is(qr/${a}{/, '(?-xism:A{)', "interpolation, qr//");
|
---|
83 | my $c = "A{";
|
---|
84 | $c =~ /${a}{/;
|
---|
85 | is($&, 'A{', "interpolation, m//");
|
---|
86 | $c =~ s/${a}{/foo/;
|
---|
87 | is($c, 'foo', "interpolation, s/...//");
|
---|
88 | $c =~ s/foo/${a}{/;
|
---|
89 | is($c, 'A{', "interpolation, s//.../");
|
---|
90 | is(<<"${a}{", "A{ A[ B{\n", "interpolation, here doc");
|
---|
91 | ${a}{ ${a}[ @{b}{
|
---|
92 | ${a}{
|
---|
93 | }
|
---|
94 |
|
---|
95 | eval q{ sub a(;; &) { } a { } };
|
---|
96 | is($@, '', "';&' sub prototype confuses the lexer");
|
---|
97 |
|
---|
98 | # Bug #21575
|
---|
99 | # ensure that the second print statement works, by playing a bit
|
---|
100 | # with the test output.
|
---|
101 | my %data = ( foo => "\n" );
|
---|
102 | print "#";
|
---|
103 | print(
|
---|
104 | $data{foo});
|
---|
105 | pass();
|
---|
106 |
|
---|
107 | # Bug #21875
|
---|
108 | # { q.* => ... } should be interpreted as hash, not block
|
---|
109 |
|
---|
110 | foreach my $line (split /\n/, <<'EOF')
|
---|
111 | 1 { foo => 'bar' }
|
---|
112 | 1 { qoo => 'bar' }
|
---|
113 | 1 { q => 'bar' }
|
---|
114 | 1 { qq => 'bar' }
|
---|
115 | 0 { q,'bar', }
|
---|
116 | 0 { q=bar= }
|
---|
117 | 0 { qq=bar= }
|
---|
118 | 1 { q=bar= => 'bar' }
|
---|
119 | EOF
|
---|
120 | {
|
---|
121 | my ($expect, $eval) = split / /, $line, 2;
|
---|
122 | my $result = eval $eval;
|
---|
123 | ok($@ eq '', "eval $eval");
|
---|
124 | is(ref $result, $expect ? 'HASH' : '', $eval);
|
---|
125 | }
|
---|
126 |
|
---|
127 | # Bug #24212
|
---|
128 | {
|
---|
129 | local $SIG{__WARN__} = sub { }; # silence mandatory warning
|
---|
130 | eval q{ my $x = -F 1; };
|
---|
131 | like( $@, qr/(?:syntax|parse) error .* near "F 1"/, "unknown filetest operators" );
|
---|
132 | is(
|
---|
133 | eval q{ sub F { 42 } -F 1 },
|
---|
134 | '-42',
|
---|
135 | '-F calls the F function'
|
---|
136 | );
|
---|
137 | }
|
---|
138 |
|
---|
139 | # Bug #24762
|
---|
140 | {
|
---|
141 | eval q{ *foo{CODE} ? 1 : 0 };
|
---|
142 | is( $@, '', "glob subscript in conditional" );
|
---|
143 | }
|
---|
144 |
|
---|
145 | # Bug #27024
|
---|
146 | {
|
---|
147 | # this used to segfault (because $[=1 is optimized away to a null block)
|
---|
148 | my $x;
|
---|
149 | $[ = 1 while $x;
|
---|
150 | pass();
|
---|
151 | $[ = 0; # restore the original value for less side-effects
|
---|
152 | }
|
---|
153 |
|
---|
154 | # [perl #2738] perl segfautls on input
|
---|
155 | {
|
---|
156 | eval q{ sub _ <> {} };
|
---|
157 | like($@, qr/Illegal declaration of subroutine main::_/, "readline operator as prototype");
|
---|
158 |
|
---|
159 | eval q{ $s = sub <> {} };
|
---|
160 | like($@, qr/Illegal declaration of anonymous subroutine/, "readline operator as prototype");
|
---|
161 |
|
---|
162 | eval q{ sub _ __FILE__ {} };
|
---|
163 | like($@, qr/Illegal declaration of subroutine main::_/, "__FILE__ as prototype");
|
---|
164 | }
|
---|
165 |
|
---|
166 | # [perl #36313] perl -e "1for$[=0" crash
|
---|
167 | {
|
---|
168 | my $x;
|
---|
169 | $x = 1 for ($[) = 0;
|
---|
170 | pass('optimized assignment to $[ used to segfault in list context');
|
---|
171 | if ($[ = 0) { $x = 1 }
|
---|
172 | pass('optimized assignment to $[ used to segfault in scalar context');
|
---|
173 | $x = ($[=2.4);
|
---|
174 | is($x, 2, 'scalar assignment to $[ behaves like other variables');
|
---|
175 | $x = (($[) = 0);
|
---|
176 | is($x, 1, 'list assignment to $[ behaves like other variables');
|
---|
177 | $x = eval q{ ($[, $x) = (0) };
|
---|
178 | like($@, qr/That use of \$\[ is unsupported/,
|
---|
179 | 'cannot assign to $[ in a list');
|
---|
180 | eval q{ ($[) = (0, 1) };
|
---|
181 | like($@, qr/That use of \$\[ is unsupported/,
|
---|
182 | 'cannot assign list of >1 elements to $[');
|
---|
183 | eval q{ ($[) = () };
|
---|
184 | like($@, qr/That use of \$\[ is unsupported/,
|
---|
185 | 'cannot assign list of <1 elements to $[');
|
---|
186 | }
|
---|