kivitendo/t/007broken_links.t @ dc7162f3
58640fb9 | Sven Schöling | #!/usr/bin/perl
|
||
d60e7dee | Sven Schöling | # adapted from Michael Stevens' test script posted in p5p
|
||
# in the thread "broken links in blead" from 01/19/2011
|
||||
#
|
||||
# caveats: wikipedia seems to have crawler protection and
|
||||
# will give 403 forbidden unless the user agent is faked.
|
||||
58640fb9 | Sven Schöling | use strict;
|
||
use File::Find;
|
||||
68a7345e | Sven Schöling | use Test::More;
|
||
if (eval " use LWP::Simple; use URI::Find; 1 ") {
|
||||
plan tests => 1;
|
||||
} else {
|
||||
plan skip_all => "LWP::Simple or URI::Find not installed";
|
||||
}
|
||||
58640fb9 | Sven Schöling | |||
my @fails;
|
||||
my $finder = URI::Find->new(sub {
|
||||
my ($uri_obj, $uri_text) = @_;
|
||||
$uri_text =~ s/^\<//;
|
||||
$uri_text =~ s/\>$//;
|
||||
push @fails, "$uri_text in file $File::Find::name"
|
||||
if !defined get($uri_text);
|
||||
return $_[1];
|
||||
});
|
||||
find(sub {
|
||||
a0144a09 | Sven Schöling | return unless -f $File::Find::name;
|
||
58640fb9 | Sven Schöling | open(FH, $File::Find::name) or return;
|
||
my $text;
|
||||
{ local $/; $text = <FH>; }
|
||||
$finder->find(\$text);
|
||||
51488052 | Sven Schöling | }, "./templates", "./doc",
|
||
);
|
||||
58640fb9 | Sven Schöling | |||
if (@fails) {
|
||||
ok(0, join "\n", @fails);
|
||||
} else {
|
||||
ok(1, "no broken links found");
|
||||
}
|