X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2F12-fail.t;h=7a6f9f08f60cbd7ae4b63e653e5d914970500e14;hb=1ec979a85aff746de645b4670694940728a9fb7c;hp=a5387d1078ab53aba17772a2039df19b5d070be0;hpb=ece2d635e9ab37330538036f1cccc1e588f826c4;p=catagits%2FTest-EOL.git diff --git a/t/12-fail.t b/t/12-fail.t index a5387d1..7a6f9f0 100644 --- a/t/12-fail.t +++ b/t/12-fail.t @@ -3,69 +3,96 @@ use strict; use Test::More qw(no_plan); use File::Temp qw( tempdir tempfile ); - my $perl = $^X || 'perl'; -my $inc = join(' -I ', @INC) || ''; +my $inc = join(' -I ', map { qq{"$_"} } @INC) || ''; $inc = "-I $inc" if $inc; { - my $dir = make_bad_file_1(); - my (undef, $outfile) = tempfile(); - ok( `$perl $inc -MTest::EOL -e "all_perl_files_ok( '$dir' )" 2>&1 > $outfile` ); + my ( $dir, $filename ) = make_raw_badfile(); local $/ = undef; - open my $fh, '<', $outfile or die $!; + open my $fh, '<', $filename or die $!; + binmode( $fh, ':raw' ); my $content = <$fh>; - like( $content, qr/^not ok 1 - No windows line endings in '[^']*' on line 4/m, 'windows EOL found in tmp file 1' ); - unlink $outfile; + 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(); - my (undef, $outfile) = tempfile(); - ok( `$perl $inc -MTest::EOL -e "all_perl_files_ok( '$dir' )" 2>&1 > $outfile` ); - open my $fh, '<', $outfile or die $!; - local $/ = undef; - my $content = <$fh>; - like( $content, qr/^not ok 1 - No windows line endings in '[^']*' on line \d+/m, 'windows EOL found in tmp file2 ' ); - unlink $outfile; + 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(); - my (undef, $outfile) = tempfile(); - ok( `$perl $inc -MTest::EOL -e "all_perl_files_ok( '$file' )" 2>&1 > $outfile` ); - open my $fh, '<', $outfile or die $!; - local $/ = undef; - my $content = <$fh>; - like( $content, qr/^not ok 1 - No windows line endings in '[^']*' on line \d+/m, 'windows EOL found in tmp file 3' ); - unlink $outfile; + run_ok( "all_perl_files_ok( '$file' )", + qr/^not ok 1 - No incorrect line endings in '[^']*' \Qon line 9: [\r][\r][\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(); - ok( `$perl $inc -MTest::EOL -e "all_perl_files_ok({trailing_whitespace => 1}, '$dir' )" 2>&1 > $outfile` ); - open my $fh, '<', $outfile or die $!; + 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, qr/^not ok 1 - No windows line endings in '[^']*' on line \d+/m, 'windows EOL found in tmp file 4' ); + like( $content, $match, $test_name ); unlink $outfile; } +sub ascii_string { + my $o = ""; + 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' ); - print $fh <<"DUMMY"; + 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 @@ -74,11 +101,11 @@ sub make_bad_file_2 { =head1 NAME test.pL - A test script - +\r\r\r\r\r\r\r\r =cut sub main { - print "Hello!\n"; + print "Hello!\\n"; } DUMMY return $tmpdir; @@ -87,19 +114,20 @@ DUMMY 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; - -package My::Test; - -sub new { - my (\$class) = @_; - my \$self = bless { }, \$class; - return \$self; -} - - -1; +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\r + +\r +1;\r DUMMY close $fh; return ($tmpdir, $filename); @@ -108,7 +136,8 @@ DUMMY sub make_bad_file_4 { my $tmpdir = tempdir( CLEANUP => 1 ); my ($fh, $filename) = tempfile( DIR => $tmpdir, SUFFIX => '.pL' ); - print $fh <<"DUMMY"; + binmode $fh, ':raw'; + print $fh <<'DUMMY'; #!perl =pod @@ -122,7 +151,7 @@ test.pL - A test script sub main { DUMMY -print $fh qq{ print "Hello!\n"; \n}; # <-- whitespace +print $fh qq{ print "Hello!\\n"; \t \n}; # <-- whitespace print $fh '}'; return $tmpdir;