X-Git-Url: http://git.vanrenterghem.biz/git.ikiwiki.info.git/blobdiff_plain/9c5f4761d8bf785ca98d5fda66fbbe9dbe11897c..883880b46ddc0d650f70bd6ca2a22539ff78f1b6:/t/basewiki_brokenlinks.t

diff --git a/t/basewiki_brokenlinks.t b/t/basewiki_brokenlinks.t
index 00811a5e3..26e3859ab 100755
--- a/t/basewiki_brokenlinks.t
+++ b/t/basewiki_brokenlinks.t
@@ -1,12 +1,42 @@
 #!/usr/bin/perl
 use warnings;
 use strict;
-use Test::More 'no_plan';
-
-ok(! system("mkdir t/tmp"));
-ok(! system("make -q ikiwiki.out"));
-ok(! system("make extra_install DESTDIR=t/tmp/install PREFIX=/usr >/dev/null"));
-ok(! system("LANG= perl -T -I. ./ikiwiki.out -plugin smiley -plugin brokenlinks -rebuild -underlaydir=t/tmp/install/usr/share/ikiwiki/basewiki -templatedir=templates t/basewiki_brokenlinks t/tmp/out"));
-ok(`grep 'no broken links' t/tmp/out/index.html`);
-ok(-e "t/tmp/out/style.css");
-ok(! system("rm -rf t/tmp t/basewiki_brokenlinks/.ikiwiki"));
+use Test::More;
+
+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. ./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 '<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"));
+
+done_testing();