alnk once again points out that mst is an idiot
[scpubgit/Q-Branch.git] / xt / 91podcoverage.t
1 use warnings;
2 use strict;
3
4 use Test::More;
5
6 use Pod::Coverage 0.19;
7 use Test::Pod::Coverage 1.04;
8
9 my @modules = sort { $a cmp $b } ( Test::Pod::Coverage::all_modules() );
10
11 # Since this is about checking documentation, a little documentation
12 # of what this is doing might be in order...
13 # The exceptions structure below is a hash keyed by the module
14 # name.  The value for each is a hash, which contains one or more
15 # (although currently more than one makes no sense) of the following
16 # things:-
17 #   skip   => a true value means this module is not checked
18 #   ignore => array ref containing list of methods which
19 #             do not need to be documented.
20 my $exceptions = {
21     'SQL::Abstract' => { ignore => [qw(
22       belch
23       puke
24       DETECT_AUTOGENERATED_STRINGIFICATION
25     )]},
26     'SQL::Abstract::Tree' => { ignore => [qw(BUILDARGS)] },
27     'SQL::Abstract::Test' => { skip => 1 },
28     'SQL::Abstract::Formatter' => { skip => 1 },
29     'SQL::Abstract::Parts' => { skip => 1 },
30     'DBIx::Class::Storage::Debug::PrettyPrint' => { skip => 1 },
31 };
32
33 foreach my $module (@modules) {
34   SKIP:
35     {
36         skip "$module - No user visible methods",
37           1
38           if ( $exceptions->{$module}{skip} );
39
40         # build parms up from ignore list
41         my $parms = {};
42         $parms->{trustme} =
43           [ map { qr/^$_$/ } @{ $exceptions->{$module}{ignore} } ]
44           if exists( $exceptions->{$module}{ignore} );
45
46         # run the test with the potentially modified parm set
47         pod_coverage_ok( $module, $parms, "$module POD coverage" );
48     }
49 }
50
51 done_testing;