NAME
Test::Pod::LinkCheck::Lite - Test POD links
SYNOPSIS
use Test::More 0.88; # for done_testing();
use Test::Pod::LinkCheck::Lite;
my $t = Test::Pod::LinkCheck::Lite->new();
$t->all_pod_files_ok();
done_testing;
DESCRIPTION
This Perl module tests POD links. A given file generates one failure for each broken link found. If no broken links are found, one passing test is generated. This all means that you can not know how many tests will be generated, and you will need to use Test::More's done_testing()
at the end of your test.
This module should probably be considered alpha-quality code at this point. It correctly checks most of my modest corpus, but beyond that deponent sayeth not.
This module started its life as a low-dependency version of Test::Pod::LinkCheck. Significant differences from that module include:
- Minimal use of the shell
-
This module shells out only to check
man
links. - Unchecked links are explicitly skipped
-
That is, a skipped test is generated for each. Note that Test::Pod::LinkCheck appears to fail the link in at least some such cases.
- URL links are checked
-
This seemed to be an easy enough addition.
- Dependencies are minimized
-
Given at least Perl 5.13.9, the only non-core module used is B::Keywords.
POD links come in the following flavors:
man
These links are of the form
L<manpage (section)>
. They will only be checked if theman
attribute is true, and can only be successfully checked if theman
command actually displays man pages, andman -w
can be executed.url
These links are of the form
L<http://...>
(orhttps:
or whatever). They will only be checked if thecheck_url
attribute is true, and can only be successfully checked if Perl has access to the specified URL.pod (internal)
These links are of the form
L<text|/section>
. They are checked using the parse tree in which the link was found.pod (external)
This is pretty much everything else. There are a number of cases, and the only way to distinguish them is to run through them.
- Perl built-ins
-
These links are of the form
L<text|builtin>>
orL<builtin>
, and are checked against the lists in B::Keywords. - Installed modules and pod files
-
These are resolved to a file using Pod::Perldoc. If a section was specified, the file is parsed to determine whether the section name is valid.
- Uninstalled modules
-
These are checked against modules/02packages.details.txt.gz, provided that (or some reasonable facsimile) can be found. Currently we can look for this information in the following places:
- File Metadata in the directory used by the
CPAN
client; - Website https://cpanmetadb.plackperl.org/, a.k.a. the CPAN Meta DB.
If more than one of these is configured (by default they all are), we look in the newest one.
Sections can not be checked. If a link to a valid (but uninstalled) module has a section, a skipped test is generated.
- File Metadata in the directory used by the
The ::Lite
refers to the fact that a real effort has been made to reduce non-core dependencies. Under Perl 5.14 and up, the only known non-core dependencies are B::Keywords and Pod::Simple::SimpleTree.
An effort has also been made to minimize the spawning of system commands.
METHODS
This class supports the following public methods:
new
my $t = Test::Pod::LinkCheck::Lite->new();
This static method instantiates an object. Optional arguments are passed as name/value pairs.
The following arguments are supported:
- agent
-
This argument is the user agent string to use for web access.
The default is that of HTTP::Tiny.
- check_external_sections
-
This Boolean argument is true if the sections of links outside the current Pod are to be checked. If it is false, such sections are not checked, and the link is considered valid if the external Pod exists at all.
The default is true.
- check_url
-
This Boolean argument is true if
url
links are to be checked, and false if not.The default is true.
- ignore_url
-
This argument specifies one or more URLs to ignore when checking
url
links. It can be specified as:- A
Regexp
object -
Any URL that matches this Regexp is ignored.
undef
-
No URLs are ignored.
- a scalar
-
This URL is ignored.
- a scalar reference
-
The URL referred to is ignored.
- a hash reference
-
The URL is ignored if the hash contains a true value for the URL.
- a code reference
-
The code is called with the URL to ignore in the topic variable (a.k.a.
$_
). The URL is ignored if the code returns a true value. - an
ARRAY
reference -
The array can contain any legal ignore specification, and any URL that matches any value in the array is ignored. Nested arrays are flattened.
The default is
[]
.Note that the order in which the individual checks are made is undefined. OK, the implementation is deterministic, but the order of evaluation is an implementation detail that the author reserves the right to change without warning.
- A
- man
-
This Boolean argument is true if
man
links are to be checked, and false if not. The default is the value ofIPC::Cmd::can_run( 'man' )
. If this returns false a warning is generated, andman
links are not checked. - module_index
-
This argument specifies a list of module indices to consult, as either a comma-delimited string or an array reference. Even if specified a given index will only be used if it is actually available for use. If more than one index is found, the most-recently-updated index will be used. Possible indices are:
- cpan
-
Use the module index found in the CPAN working directory.
- cpan_meta_db
-
Use the CPAN Meta database. Because this is an on-line index it is considered to be current, but its as-of time is offset to favor local indices.
By default all indices are considered.
- require_installed
-
This Boolean argument is true to disable the uninstalled module checks. This means links to modules not installed on the system will fail, even if the module exists.
By default this is false.
agent
This method returns the value of the 'agent'
attribute.
all_pod_files_ok
$t->all_pod_files_ok();
This method takes as its arguments the names of one or more files, and tests any such that are deemed to be Perl files. Directories are recursed into.
Perl files are considered to be all text files whose names end in .pod, .pm, or .PL, plus any text files with a shebang line containing 'perl'
. File name suffixes are case-sensitive except for .PL.
If no arguments are specified, the contents of blib/ are tested. This is the recommended usage.
If called in scalar context, this method returns the number of test failures encountered. If called in list context it return the number of failures, passes, and skipped tests, in that order.
check_external_sections
$t->check_external_sections()
and say 'Sections in external links are checked';
This method returns the value of the 'check_url'
attribute.
check_url
$t->check_url() and say 'URL links are checked';
This method returns the value of the 'check_url'
attribute.
ignore_url
print 'Ignored URLs ', join ', ', $t->ignore_url();
This method returns the value of the 'ignore_url'
attribute. If called in scalar context, it returns an array reference. If called in list context it returns an array. Either way, the results will not be in the same order as originally specified to new().
man
$t->man() and say 'man links are checked';
This method returns the value of the 'man'
attribute.
module_index
say 'Module indices: ', join ', ', $self->module_index();
This method returns the value of the 'module_index'
attribute. If called in scalar context it returns a comma-delimited string.
pod_file_ok
my $failures = $t->pod_file_ok( 'lib/Foo/Bar.pm' );
This method tests the links in the given file. Each failure appears in the TAP output as a test failure. If no failures are found, a passing test will appear in the TAP output.
If called in scalar context, this method returns the number of test failures encountered. If called in list context it return the number of failures, passes, and skipped tests, in that order.
require_installed
$t->require_installed()
and say 'All POD links must be to installed modules';
This method returns the value of the 'require_installed'
attribute.
SEE ALSO
Test::Pod::LinkCheck by Apocalypse checks all POD links except for URLs. It is Moose-based.
Test::Pod::Links by Sven Kirmess checks all URLs or URL-like things in the document, whether or not they are actual POD links.
Test::Pod::No404s by Apocalypse checks URL POD links.
SUPPORT
Support is by the author. Please file bug reports at http://rt.cpan.org, or in electronic mail to the author.
AUTHOR
Thomas R. Wyant, III wyant at cpan dot org
COPYRIGHT AND LICENSE
Copyright (C) 2019 by Thomas R. Wyant, III
This program is free software; you can redistribute it and/or modify it under the same terms as Perl 5.10.0. For more details, see the full text of the licenses in the directory LICENSES.
This program is distributed in the hope that it will be useful, but without any warranty; without even the implied warranty of merchantability or fitness for a particular purpose.