This is a live mirror of the Perl 5 development currently hosted at https://github.com/perl/perl5
Re: Patch lint for grep { /.../ } and grep /.../,
[perl5.git] / ext / B / t / lint.t
1 #!./perl -w
2
3 BEGIN {
4     if ($ENV{PERL_CORE}){
5         chdir('t') if -d 't';
6         @INC = ('.', '../lib');
7     } else {
8         unshift @INC, 't';
9         push @INC, "../../t";
10     }
11     require Config;
12     if (($Config::Config{'extensions'} !~ /\bB\b/) ){
13         print "1..0 # Skip -- Perl configured without B module\n";
14         exit 0;
15     }
16     require 'test.pl';
17 }
18
19 plan tests => 18; # adjust also number of skipped tests !
20
21 # Runs a separate perl interpreter with the appropriate lint options
22 # turned on
23 sub runlint ($$$;$) {
24     my ($opts,$prog,$result,$testname) = @_;
25     my $res = runperl(
26         switches => [ "-MO=Lint,$opts" ],
27         prog     => $prog,
28         stderr   => 1,
29     );
30     $res =~ s/-e syntax OK\n$//;
31     is( $res, $result, $testname || $opts );
32 }
33
34 runlint 'context', '$foo = @bar', <<'RESULT';
35 Implicit scalar context for array in scalar assignment at -e line 1
36 RESULT
37
38 runlint 'context', '$foo = length @bar', <<'RESULT';
39 Implicit scalar context for array in length at -e line 1
40 RESULT
41
42 runlint 'implicit-read', '/foo/', <<'RESULT';
43 Implicit match on $_ at -e line 1
44 RESULT
45
46 runlint 'implicit-read', 'grep /foo/, ()', '';
47
48 runlint 'implicit-read', 'grep { /foo/ } ()', '';
49
50 runlint 'implicit-write', 's/foo/bar/', <<'RESULT';
51 Implicit substitution on $_ at -e line 1
52 RESULT
53
54 {
55     my $res = runperl(
56         switches => [ "-MB::Lint" ],
57         prog => 'BEGIN{B::Lint->register_plugin(X=>[q[x]])};use O(qw[Lint x]);sub X::match{warn qq[X ok.\n]};dummy()',
58         stderr => 1,
59     );
60     like( $res, qr/X ok\./, 'Lint plugin' );
61 }
62
63 SKIP : {
64
65     use Config;
66     skip("Doesn't work with threaded perls",11)
67        if $Config{useithreads} || ($] < 5.009 && $Config{use5005threads});
68
69     runlint 'implicit-read', '1 for @ARGV', <<'RESULT', 'implicit-read in foreach';
70 Implicit use of $_ in foreach at -e line 1
71 RESULT
72
73     runlint 'dollar-underscore', '$_ = 1', <<'RESULT';
74 Use of $_ at -e line 1
75 RESULT
76
77     runlint 'dollar-underscore', 'print', <<'RESULT', 'dollar-underscore in print';
78 Use of $_ at -e line 1
79 RESULT
80
81     runlint 'private-names', 'sub A::_f{};A::_f()', <<'RESULT';
82 Illegal reference to private name _f at -e line 1
83 RESULT
84
85     runlint 'private-names', '$A::_x', <<'RESULT';
86 Illegal reference to private name _x at -e line 1
87 RESULT
88
89     runlint 'private-names', 'sub A::_f{};A->_f()', <<'RESULT',
90 Illegal reference to private method name _f at -e line 1
91 RESULT
92     'private-names (method)';
93
94     runlint 'undefined-subs', 'foo()', <<'RESULT';
95 Undefined subroutine foo called at -e line 1
96 RESULT
97
98     runlint 'regexp-variables', 'print $&', <<'RESULT';
99 Use of regexp variable $& at -e line 1
100 RESULT
101
102     runlint 'regexp-variables', 's/./$&/', <<'RESULT';
103 Use of regexp variable $& at -e line 1
104 RESULT
105
106     runlint 'bare-subs', 'sub bare(){1};$x=bare', '';
107
108     runlint 'bare-subs', 'sub bare(){1}; $x=[bare=>0]; $x=$y{bare}', <<'RESULT';
109 Bare sub name 'bare' interpreted as string at -e line 1
110 Bare sub name 'bare' interpreted as string at -e line 1
111 RESULT
112
113 }