NAME Pod::Coverage::TrustMe - Pod::Coverage but more powerful SYNOPSIS use Pod::Coverage::TrustMe; Pod::Coverage::TrustMe->new(package => 'My::Package')->print_report; DESCRIPTION Checks that all of the functions or methods provided by a package have documentation. Compatible with most uses of Pod::Coverage, but with additional features. CONSTRUCTOR OPTIONS These options can be passed to "Pod::Coverage::TrustMe->new". package The package to check coverage for. The module must be loadable. pod_from The Pod file to parse. By default, the module that is loaded will be used, or a pod file existing in the same directory, if it exists. private An array ref of regular expressions for subs to consider private and not needing to be documented. If non-regular expressions are included in the list, they will be taken as literal sub names. Defaults to "DEFAULT_PRIVATE". also_private An array ref of items to add to the private list. Makes it easy to augment the default list. trustme An array ref of subs to consider documented even if no pod can be found. Has a similar effect to "private", but will include the subs in the list of covered subs, rather than excluding them from the list entirely. nonwhitespace Requires that the pod section for the sub have some non-whitespace characters in it to be counted as covering the sub. trust_parents Includes Pod from parent classes in list of covered subs. Like Pod::Coverage::CountParents. Defaults to true. trust_roles Includes Pod from consumed roles in list of covered subs. Like Pod::Coverage::CountParents, but checking "does" or "DOES". Defaults to true. trust_pod Trusts subs or regexes listed in "Pod::Coverage" blocks in Pod. Like Pod::Coverage::TrustPod. Defaults to true. A section like: =for Pod::Coverage sub1 sub2 [A-Z_]+ will allow the subs "sub1", "sub2", and any sub that is all upper case to exist without being documented. require_link Requires a link in the Pod to parent classes or roles to include them in the coverage. If the documentation for subs is in different files, they should be linked to in some way. export_only Only requires subs listed in @EXPORT and @EXPORT_OK to be covered. ignore_imported Ignore subs that were imported from other packages. If set to false, every sub in the package needs to be covered, even if it is imported from another package. Subs that aren't part of the API should be cleaned using a tool like namespace::clean, or excluded in some way. See also Test::CleanNamespaces. Defaults to true. METHODS coverage Returns the percentage of subs covered as a value between 0 and 1. why_unrated covered Returns a list of subs that are covered by the documentation. uncovered Returns a list of subs that are not covered by the documentation. naked An alias for uncovered. report Returns a text report on the covered and uncovered subroutines. print_report Print a text report on the covered and uncovered subroutines. symbols Returns the a hashref of symbols detected, with a value of true or false for if the symbol is covered by pod. trusted_packages Returns the other packages that will have their pod checked for symbols to treat as covered. METHODS FOR SUBCLASSES There are some private methods provided that could be overridden in subclasses to adjust the behavior. _get_syms($package) Returns the list of symbols for a given package. _get_pods($package) Returns an array ref of all of the covered items in the pod. _private_check($symbol) Returns true if the given symbol should be considered private. _trustme_check($symbol) Returns true if the given symbol should be treated as covered even without any documentation found. CONSTANTS DEFAULT_PRIVATE An array reference of the default list of private regular expressions. TESTING See Test::Pod::Coverage::TrustMe for using this module in tests. Pod::Coverage::TrustMe vs Pod::Coverage There are some important differences between this module and Pod::Coverage, aside from the additional features. No _CvGV method Pod::Coverage provides and documents the _CvGV method, but doesn't use it itself. This module does not provide the method. No import method Pod::Coverage provides an import method to allow you to run code like "perl -MPod::Coverage=Some::Package -e1". This module does not provide this, instead encouraging the use of the pod-cover script. Uses Pod::Simple Pod::Coverage parses pod using Pod::Parser, which has been removed from perl core and its use is discouraged. This module uses Pod::Simple instead. AUTHOR haarg - Graham Knop (cpan:HAARG) <haarg@haarg.org> CONTRIBUTORS None so far. COPYRIGHT Copyright (c) 2020 the Pod::Coverage::TrustMe "AUTHOR" and "CONTRIBUTORS" as listed above. LICENSE This library is free software and may be distributed under the same terms as perl itself. See <https://dev.perl.org/licenses/>.