X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=xt%2Feol.t;h=da4ef1078eb44622a20d96320ed9d93e4d825341;hb=331886ef1b5ab7a732915b8213dd525a3ea63b88;hp=d5e9d423e86fcea58db998b97e433d3869d2fbd1;hpb=47589465c9677bec08eff05300ec921d91ad25d2;p=dbsrgits%2FDBIx-Class.git diff --git a/xt/eol.t b/xt/eol.t index d5e9d42..da4ef10 100644 --- a/xt/eol.t +++ b/xt/eol.t @@ -2,6 +2,7 @@ use warnings; use strict; use Test::More; +use File::Glob 'bsd_glob'; use lib 't/lib'; use DBICTest; @@ -13,12 +14,38 @@ unless ( DBIx::Class::Optional::Dependencies->req_ok_for ('test_eol') ) { : plan skip_all => "Test needs: $missing" } +# FIXME - temporary workaround for RT#82032 +# also add all scripts (no extension) and some extra extensions +# we want to check +{ + no warnings 'redefine'; + + *Test::EOL::_is_perl_module = sub { + $_[0] !~ /\./ || $_[0] =~ /\.(?:pm|pod|skip|json|proto)$/i || $_[0] =~ /::/; + } +} + Test::EOL::all_perl_files_ok({ trailing_whitespace => 1 }, - qw/t xt lib script examples maint .generated_pod/, + qw/t xt lib script examples maint/, ); -# Changes is not a "perl file", hence checked separately -Test::EOL::eol_unix_ok('Changes', { trailing_whitespace => 1 }); +# check some non-"perl files" in the root separately +# use .gitignore as a guide of what to skip +# (or do not test at all if no .gitignore is found) +if (open(my $gi, '<', '.gitignore')) { + my $skipnames; + while (my $ln = <$gi>) { + next if $ln =~ /^\s*$/; + chomp $ln; + $skipnames->{$_}++ for bsd_glob($ln); + } + + for my $fn (bsd_glob('*')) { + next if $skipnames->{$fn}; + next unless -f $fn; + Test::EOL::eol_unix_ok($fn, { trailing_whitespace => 1 }); + } +} # FIXME - Test::EOL declares 'no_plan' which conflicts with done_testing # https://github.com/schwern/test-more/issues/14