Merge 'connect_info_hash' into 'trunk'
[dbsrgits/DBIx-Class.git] / t / 03podcoverage.t
CommitLineData
0fe5201a 1use Test::More;
2
f09cd1d4 3eval "use Pod::Coverage 0.19";
4plan skip_all => 'Pod::Coverage 0.19 required' if $@;
0fe5201a 5eval "use Test::Pod::Coverage 1.04";
6plan skip_all => 'Test::Pod::Coverage 1.04 required' if $@;
f09cd1d4 7
b20edc27 8plan skip_all => 'set TEST_POD to enable this test'
9 unless ($ENV{TEST_POD} || -e 'MANIFEST.SKIP');
0fe5201a 10
97fec99f 11my @modules = sort { $a cmp $b } (Test::Pod::Coverage::all_modules());
7eb4ecc8 12plan tests => scalar(@modules);
13
9b83fccd 14# Since this is about checking documentation, a little documentation
15# of what this is doing might be in order...
16# The exceptions structure below is a hash keyed by the module
17# name. The value for each is a hash, which contains one or more
18# (although currently more than one makes no sense) of the following
19# things:-
20# skip => a true value means this module is not checked
21# ignore => array ref containing list of methods which
22# do not need to be documented.
7eb4ecc8 23my $exceptions = {
24 'DBIx::Class' => {
517ba890 25 ignore => [qw/
26 MODIFY_CODE_ATTRIBUTES
27 component_base_class
28 mk_classdata
29 mk_classaccessor
30 /]
b20edc27 31 },
0c62fa59 32 'DBIx::Class::Row' => {
517ba890 33 ignore => [qw/
34 MULTICREATE_DEBUG
35 /],
0c62fa59 36 },
bc984450 37 'DBIx::Class::ResultSource' => {
38 ignore => [qw/
517ba890 39 compare_relationship_keys
40 pk_depends_on
41 resolve_condition
42 resolve_join
43 resolve_prefetch
44 /],
45 },
46 'DBIx::Class::ResultSourceHandle' => {
47 ignore => [qw/
48 schema
49 source_moniker
bc984450 50 /],
51 },
b20edc27 52 'DBIx::Class::Storage' => {
517ba890 53 ignore => [qw/
54 schema
55 cursor
56 /]
7eb4ecc8 57 },
249963d4 58 'DBIx::Class::Schema' => {
517ba890 59 ignore => [qw/
60 setup_connection_class
61 /]
249963d4 62 },
00c937a2 63 'DBIx::Class::Storage::DBI::Sybase' => {
517ba890 64 ignore => [qw/
65 should_quote_data_type
66 /]
00c937a2 67 },
9b83fccd 68 'DBIx::Class::CDBICompat::AccessorMapping' => { skip => 1 },
d03c0706 69 'DBIx::Class::CDBICompat::AbstractSearch' => {
70 ignore => [qw(search_where)]
71 },
9b83fccd 72 'DBIx::Class::CDBICompat::AttributeAPI' => { skip => 1 },
73 'DBIx::Class::CDBICompat::AutoUpdate' => { skip => 1 },
5ef62e9f 74 'DBIx::Class::CDBICompat::ColumnsAsHash' => {
75 ignore => [qw(inflate_result new update)]
76 },
9b83fccd 77 'DBIx::Class::CDBICompat::ColumnCase' => { skip => 1 },
78 'DBIx::Class::CDBICompat::ColumnGroups' => { skip => 1 },
79 'DBIx::Class::CDBICompat::Constraints' => { skip => 1 },
80 'DBIx::Class::CDBICompat::Constructor' => { skip => 1 },
d03c0706 81 'DBIx::Class::CDBICompat::Copy' => {
82 ignore => [qw(copy)]
83 },
9b83fccd 84 'DBIx::Class::CDBICompat::DestroyWarning' => { skip => 1 },
85 'DBIx::Class::CDBICompat::GetSet' => { skip => 1 },
86 'DBIx::Class::CDBICompat::HasA' => { skip => 1 },
87 'DBIx::Class::CDBICompat::HasMany' => { skip => 1 },
88 'DBIx::Class::CDBICompat::ImaDBI' => { skip => 1 },
89 'DBIx::Class::CDBICompat::LazyLoading' => { skip => 1 },
90 'DBIx::Class::CDBICompat::LiveObjectIndex' => { skip => 1 },
91 'DBIx::Class::CDBICompat::MightHave' => { skip => 1 },
fd8ff563 92 'DBIx::Class::CDBICompat::NoObjectIndex' => { skip => 1 },
9b83fccd 93 'DBIx::Class::CDBICompat::Pager' => { skip => 1 },
94 'DBIx::Class::CDBICompat::ReadOnly' => { skip => 1 },
aa11d765 95 'DBIx::Class::CDBICompat::Relationship' => { skip => 1 },
96 'DBIx::Class::CDBICompat::Relationships' => { skip => 1 },
9b83fccd 97 'DBIx::Class::CDBICompat::Retrieve' => { skip => 1 },
4a534c04 98 'DBIx::Class::CDBICompat::SQLTransformer' => { skip => 1 },
9b83fccd 99 'DBIx::Class::CDBICompat::Stringify' => { skip => 1 },
100 'DBIx::Class::CDBICompat::TempColumns' => { skip => 1 },
101 'DBIx::Class::CDBICompat::Triggers' => { skip => 1 },
102 'DBIx::Class::ClassResolver::PassThrough' => { skip => 1 },
103 'DBIx::Class::Componentised' => { skip => 1 },
104 'DBIx::Class::Relationship::Accessor' => { skip => 1 },
105 'DBIx::Class::Relationship::BelongsTo' => { skip => 1 },
106 'DBIx::Class::Relationship::CascadeActions' => { skip => 1 },
107 'DBIx::Class::Relationship::HasMany' => { skip => 1 },
108 'DBIx::Class::Relationship::HasOne' => { skip => 1 },
109 'DBIx::Class::Relationship::Helpers' => { skip => 1 },
110 'DBIx::Class::Relationship::ManyToMany' => { skip => 1 },
111 'DBIx::Class::Relationship::ProxyMethods' => { skip => 1 },
112 'DBIx::Class::ResultSetProxy' => { skip => 1 },
cb136e67 113 'DBIx::Class::ResultSetManager' => { skip => 1 },
9b83fccd 114 'DBIx::Class::ResultSourceProxy' => { skip => 1 },
517ba890 115 'DBIx::Class::Storage::Statistics' => { skip => 1 },
046ad905 116 'DBIx::Class::Storage::DBI' => { skip => 1 },
0ccd1cf5 117 'DBIx::Class::Storage::DBI::Replicated::Types' => { skip => 1 },
9b83fccd 118 'DBIx::Class::Storage::DBI::DB2' => { skip => 1 },
119 'DBIx::Class::Storage::DBI::MSSQL' => { skip => 1 },
9c541170 120 'DBIx::Class::Storage::DBI::Sybase::MSSQL' => { skip => 1 },
9b83fccd 121 'DBIx::Class::Storage::DBI::ODBC400' => { skip => 1 },
122 'DBIx::Class::Storage::DBI::ODBC::DB2_400_SQL' => { skip => 1 },
f41593b6 123 'DBIx::Class::Storage::DBI::ODBC::Microsoft_SQL_Server' => { skip => 1 },
9b83fccd 124 'DBIx::Class::Storage::DBI::Oracle' => { skip => 1 },
125 'DBIx::Class::Storage::DBI::Pg' => { skip => 1 },
126 'DBIx::Class::Storage::DBI::SQLite' => { skip => 1 },
127 'DBIx::Class::Storage::DBI::mysql' => { skip => 1 },
7479c654 128 'DBIx::Class::Storage::DBI::AutoCast' => { skip => 1 },
0ccd1cf5 129 'DBIx::Class::SQLAHacks' => { skip => 1 },
1c7ae8d1 130 'DBIx::Class::SQLAHacks::MySQL' => { skip => 1 },
ac93965c 131 'DBIx::Class::SQLAHacks::MSSQL' => { skip => 1 },
9b83fccd 132 'SQL::Translator::Parser::DBIx::Class' => { skip => 1 },
133 'SQL::Translator::Producer::DBIx::Class::File' => { skip => 1 },
737416a4 134
135# skipped because the synopsis covers it clearly
136
137 'DBIx::Class::InflateColumn::File' => { skip => 1 },
138
a2800991 139# skip connection since it's just an override
737416a4 140
a2800991 141 'DBIx::Class::Schema::Versioned' => { ignore => [ qw(connection) ] },
737416a4 142
5c1d82d2 143# don't bother since it's heavily deprecated
144 'DBIx::Class::ResultSetManager' => { skip => 1 },
7eb4ecc8 145};
146
147foreach my $module (@modules) {
148 SKIP:
149 {
0ebb0072 150 skip "$module - No real methods", 1 if ($exceptions->{$module}{skip});
7eb4ecc8 151
152 # build parms up from ignore list
153 my $parms = {};
154 $parms->{trustme} =
155 [ map { qr/^$_$/ } @{ $exceptions->{$module}{ignore} } ]
156 if exists($exceptions->{$module}{ignore});
157
158 # run the test with the potentially modified parm set
159 pod_coverage_ok($module, $parms, "$module POD coverage");
160 }
161}