X-Git-Url: http://git.vanrenterghem.biz/git.ikiwiki.info.git/blobdiff_plain/ffc06c8e4de9db33e0c5f90a759ae3eece633cee..69a0f013557733e0c78fa60d68d44a5e83eaff55:/t/basewiki_brokenlinks.t?ds=sidebyside diff --git a/t/basewiki_brokenlinks.t b/t/basewiki_brokenlinks.t old mode 100644 new mode 100755 index f70394b85..f639d0dd8 --- a/t/basewiki_brokenlinks.t +++ b/t/basewiki_brokenlinks.t @@ -1,9 +1,43 @@ #!/usr/bin/perl use warnings; use strict; -use Test::More tests => 3; +use Cwd qw(getcwd); +use Test::More; -ok(! system("make ikiwiki.out")); -ok(! system("PERL5LIB=. ./ikiwiki.out -plugin brokenlinks -rebuild -underlaydir=basewiki t/basewiki_brokenlinks t/basewiki_brokenlinks/out")); -ok(`grep 'no broken links' t/basewiki_brokenlinks/out/index.html`); -system("rm -rf t/basewiki_brokenlinks/out t/basewiki_brokenlinks/.ikiwiki"); +my $installed = $ENV{INSTALLED_TESTS}; + +ok(! system("rm -rf t/tmp; mkdir t/tmp")); + +my @command; +if ($installed) { + @command = qw(env LC_ALL=C ikiwiki); +} +else { + ok(! system("make -s ikiwiki.out")); + ok(! system("make underlay_install DESTDIR=`pwd`/t/tmp/install PREFIX=/usr >/dev/null")); + @command = (qw(env LC_ALL=C perl), "-I".getcwd, qw(./ikiwiki.out + --underlaydir=t/tmp/install/usr/share/ikiwiki/basewiki + --set underlaydirbase=t/tmp/install/usr/share/ikiwiki + --templatedir=templates)); +} + +foreach my $plugin ("", "listdirectives") { + ok(! system(@command, qw(--rebuild --plugin brokenlinks), + # always enabled because pages link to it conditionally, + # which brokenlinks cannot handle properly + qw(--plugin smiley), + ($plugin ? ("--plugin", $plugin) : ()), + qw(t/basewiki_brokenlinks t/tmp/out))); + my $result=`grep 'no broken links' t/tmp/out/index.html`; + ok(length($result)); + if (! length $result) { + print STDERR "\n\nbroken links found".($plugin ? " (with $plugin)" : "")."\n"; + system("grep '
  • ' t/tmp/out/index.html >&2"); + print STDERR "\n\n"; + } + ok(-e "t/tmp/out/style.css"); # linked to.. + ok(! system("rm -rf t/tmp/out t/basewiki_brokenlinks/.ikiwiki")); +} +ok(! system("rm -rf t/tmp")); + +done_testing();