X-Git-Url: http://git.vanrenterghem.biz/git.ikiwiki.info.git/blobdiff_plain/05fbbad4b4d256b34b2574d98a0cf1203121b782..7ab84dcfe52a37b93e6faa49895ae963a3b5d0d1:/t/basewiki_brokenlinks.t

diff --git a/t/basewiki_brokenlinks.t b/t/basewiki_brokenlinks.t
old mode 100644
new mode 100755
index d15924036..74ddc61c5
--- a/t/basewiki_brokenlinks.t
+++ b/t/basewiki_brokenlinks.t
@@ -1,9 +1,29 @@
 #!/usr/bin/perl
 use warnings;
 use strict;
-use Test::More tests => 3;
+use Test::More 'no_plan';
 
-ok(! system("make ikiwiki.out"));
-ok(! system("./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");
+ok(! system("rm -rf t/tmp; mkdir t/tmp"));
+ok(! system("make -s ikiwiki.out"));
+ok(! system("make underlay_install DESTDIR=`pwd`/t/tmp/install PREFIX=/usr >/dev/null"));
+
+foreach my $plugin ("", "listdirectives") {
+	ok(! system("LC_ALL=C perl -I. ./ikiwiki.out -rebuild -plugin brokenlinks ".
+			# always enabled because pages link to it conditionally,
+			# which brokenlinks cannot handle properly
+			"-plugin smiley ".
+			($plugin ? "-plugin $plugin " : "").
+			"-underlaydir=t/tmp/install/usr/share/ikiwiki/basewiki ".
+			"-set underlaydirbase=t/tmp/install/usr/share/ikiwiki ".
+			"-templatedir=templates 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 '<li>' 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"));