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
|
#!perl -w
#
# Test that every perl file we have passes the syntax check. This of
# course needs not only build dependencies but also run-time
# dependencies like libdbd-pg-perl installed.
#
# Steve
# --
#
use strict;
use File::Find;
use Test::More;
#
# Find all the files beneath the current directory,
# and call 'checkFile' with the name.
#
find( { wanted => \&checkFile, no_chdir => 1 }, '.' );
done_testing();
#
# Check a file.
#
# If this is a perl file then call "perl -c $name", otherwise
# return
#
sub checkFile
{
# The file.
my $file = $File::Find::name;
# We don't care about directories or symbolic links
return if ( ! -f $file );
return if ( -l $file );
# Nor about Makefiles
return if ( $file =~ /\/Makefile$/ );
# Nor about Change Logs
return if ( $file =~ /\/changelog$/i );
# Nor about git files
return if ( $file =~ /^\.\/\.git\// );
# Nor about dot files
return if ( $file =~ m{/\.[^/]+$} );
# `modules.sh` is a false positive.
return if ( $file =~ /modules.sh$/ );
# `tests/hook-tls.t` is too.
return if ( $file =~ /hook-tls.t$/ );
# Ignore cover_db files
return if ( $file =~ /^\.\/cover_db\// );
# See if it is a perl file.
my $isPerl = 0;
# Read the file.
open( INPUT, "<", $file );
foreach my $line ( <INPUT> )
{
if ( $line =~ /\/usr\/bin\/perl/ )
{
$isPerl = 1;
}
}
close( INPUT );
#
# Return if it wasn't a perl file.
#
return if ( ! $isPerl );
#
# Now run 'perl -c $file' to see if we pass the syntax
# check. We add a couple of parameters to make sure we're
# really OK.
#
# use strict "vars";
# use strict "subs";
#
my $retval = system( "perl -Mstrict=subs -Mstrict=vars -It/fake-lib -c $file" );
is( $retval, 0, "Perl file passes our syntax check: $file" );
}
|