X-Git-Url: http://git.vanrenterghem.biz/git.ikiwiki.info.git/blobdiff_plain/7c032d14659cc57cecb529e9d22177844dd71dc0..775fefeea72209cc4eae1bbe314bd94491bcb1b3:/t/basewiki_brokenlinks.t?ds=sidebyside

diff --git a/t/basewiki_brokenlinks.t b/t/basewiki_brokenlinks.t
index fbcc10554..74ddc61c5 100755
--- 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("LANG=C perl -T -I. ./ikiwiki.out -plugin brokenlinks -rebuild -underlaydir=basewiki -templatedir=templates 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"));