1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159
|
use strict;
use Test::More qw(no_plan);
use File::Temp qw( tempdir tempfile );
my $perl = $^X || 'perl';
my $inc = join(' -I ', map { qq{"$_"} } @INC) || '';
$inc = "-I $inc" if $inc;
{
my ( $dir, $filename ) = make_raw_badfile();
local $/ = undef;
open my $fh, '<', $filename or die $!;
binmode( $fh, ':raw' );
my $content = <$fh>;
is( $content, ascii_string(), 'Data written to file is there when we look for it later' );
}
{
my $dir = make_bad_file_1();
run_ok( "all_perl_files_ok( '$dir' )",
qr/^not ok 1 - No incorrect line endings in '[^']*' \Qon line 5: [\r]/m,
'windows EOL found in tmp file 1' );
}
{
my $dir = make_bad_file_2();
run_ok( "all_perl_files_ok( '$dir' )",
qr/^not ok 1 - No incorrect line endings in '[^']*' \Qon line 8: [\r][\r][\r][\r][\r][\r][\r]/m,
'windows EOL found in tmp file2 ' );
}
{
my ($dir, $file) = make_bad_file_3();
run_ok( "all_perl_files_ok( '$file' )",
qr/^not ok 1 - No incorrect line endings in '[^']*' \Qon line 1: [\r] /m,
'windows EOL found in tmp file 3' );
}
{
my $dir = make_bad_file_4();
run_ok( "all_perl_files_ok({trailing_whitespace => 1}, '$dir' )",
# Note that line number will be 13
qr/^not ok 1 - No incorrect line endings in '[^']*' \Qon line 12: [\s][\t][\s][\s]/m,
'Trailing ws EOL found in tmp file 4' );
}
sub run_ok {
my ($code, $match, $test_name) = @_;
my $line = (caller)[2];
die "code containing double quotes is not portable on Win32 in one-liners" if $code =~ /"/;
my (undef, $outfile) = tempfile();
is( `$perl $inc -MTest::EOL -e "$code" > $outfile 2>&1`, '', "test sub program at line $line: output redirected" );
is( $? >> 8, 1, "test sub program at line $line: exit code is 1" );
local $/ = undef;
open my $fh, '<', $outfile or die $!;
my $content = <$fh>;
like( $content, $match, $test_name );
unlink $outfile;
}
sub ascii_string {
my $o = "<before \r\n between \r\n after \n normal >";
return $o x 3;
}
sub make_raw_badfile {
my $tmpdir = tempdir( CLEANUP => 1 );
my ( $fh, $filename ) = tempfile( DIR => $tmpdir, SUFFIX => '.tXt' );
binmode $fh, ':raw';
print $fh ascii_string();
close $fh;
return ( $tmpdir, $filename );
}
sub make_bad_file_1 {
my $tmpdir = tempdir( CLEANUP => 1 );
my ($fh, $filename) = tempfile( DIR => $tmpdir, SUFFIX => '.pL' );
binmode $fh, ':raw';
my $str = <<"DUMMY";
#!perl
sub main {
# Note that the generated file will have the CRLF expanded in the source
print "Hello!\r\n";
}
DUMMY
print $fh $str;
return $tmpdir;
}
sub make_bad_file_2 {
my $tmpdir = tempdir( CLEANUP => 1 );
my ($fh, $filename) = tempfile( DIR => $tmpdir, SUFFIX => '.pL' );
binmode $fh, ':raw';
print $fh <<"DUMMY";
#!perl
=pod
=head1 NAME
test.pL - A test script
\r\r\r\r\r\r\r\r
=cut
sub main {
print "Hello!\\n";
}
DUMMY
return $tmpdir;
}
sub make_bad_file_3 {
my $tmpdir = tempdir( CLEANUP => 1 );
my ($fh, $filename) = tempfile( DIR => $tmpdir, SUFFIX => '.pm' );
binmode $fh, ':raw';
print $fh <<"DUMMY";
use strict;\r
\r
package My::Test;\r
\r
sub new {\r
my (\$class) = \@_;\r
my \$self = bless { }, \$class;\r
return \$self;\r
}\r
\r
\r
1;\r
DUMMY
close $fh;
return ($tmpdir, $filename);
}
sub make_bad_file_4 {
my $tmpdir = tempdir( CLEANUP => 1 );
my ($fh, $filename) = tempfile( DIR => $tmpdir, SUFFIX => '.pL' );
binmode $fh, ':raw';
print $fh <<'DUMMY';
#!perl
=pod
=head1 NAME
test.pL - A test script
=cut
sub main {
DUMMY
print $fh qq{ print "Hello!\\n"; \t \n}; # <-- whitespace
print $fh '}';
return $tmpdir;
}
|