]> git.vanrenterghem.biz Git - git.ikiwiki.info.git/blobdiff - t/podcast.t
trail: Allow unescaped punctuation in pagenames
[git.ikiwiki.info.git] / t / podcast.t
index 94505a05e2ca70dabcbdd28f4cda14be353fbf9f..7b0987e21321f2e7738b71903a8381da3361a0b1 100755 (executable)
@@ -9,13 +9,28 @@ BEGIN {
                        "XML::Feed and/or HTML::Parser or File::MimeInfo not available"};
        }
        else {
-               eval q{use Test::More tests => 136};
+               eval q{use Test::More};
        }
 }
 
 use Cwd;
 use File::Basename;
 
+my $installed = $ENV{INSTALLED_TESTS};
+
+my @base_command;
+if ($installed) {
+       ok(1, "running installed");
+       @base_command = qw(ikiwiki);
+}
+else {
+       ok(! system("make -s ikiwiki.out"));
+       @base_command = ("perl", "-I".getcwd, qw(./ikiwiki.out
+               --underlaydir=underlays/basewiki
+               --set underlaydirbase=underlays
+               --templatedir=templates));
+}
+
 my $tmp = 't/tmp';
 my $statedir = 't/tinypodcast/.ikiwiki';
 
@@ -23,10 +38,10 @@ sub podcast {
        my $podcast_style = shift;
 
        my $baseurl = 'http://example.com';
-       my @command = (qw(./ikiwiki.out -plugin inline -rss -atom));
-       push @command, qw(-underlaydir=underlays/basewiki);
-       push @command, qw(-set underlaydirbase=underlays -templatedir=templates);
-       push @command, "-url=$baseurl", qw(t/tinypodcast), "$tmp/out";
+       my @command = (@base_command, qw(--plugin inline --rss --atom));
+       push @command, "--url=$baseurl", qw(t/tinypodcast), "$tmp/out";
+
+       ok(! system("rm -rf $tmp $statedir"), q{setup});
 
        ok(! system("mkdir $tmp"),
                q{setup});
@@ -108,16 +123,14 @@ sub podcast {
                        }
                }
        }
-
-       ok(! system("rm -rf $tmp $statedir"), q{teardown});
 }
 
 sub single_page_html {
-       my @command = (qw(./ikiwiki.out));
-       push @command, qw(-underlaydir=underlays/basewiki);
-       push @command, qw(-set underlaydirbase=underlays -templatedir=templates);
+       my @command = @base_command;
        push @command, qw(t/tinypodcast), "$tmp/out";
 
+       ok(! system("rm -rf $tmp $statedir"), q{setup});
+
        ok(! system("mkdir $tmp"),
                q{setup});
        ok(! system(@command),
@@ -130,7 +143,7 @@ sub single_page_html {
                q{html enclosure});
        my ($href) = _extract_html_links($html, 'piano');
        is($href, '/piano.mp3',
-               q{html enclosure sans -url is site-absolute});
+               q{html enclosure sans --url is site-absolute});
 
        $html = "$tmp/out/attempted_multiple_enclosures/index.html";
        like(_extract_html_content($html, 'content'), qr/has content and/m,
@@ -139,30 +152,30 @@ sub single_page_html {
                q{html enclosure});
        ($href) = _extract_html_links($html, 'walter');
        is($href, '/walter.ogg',
-               q{html enclosure sans -url is site-absolute});
+               q{html enclosure sans --url is site-absolute});
 
        my $baseurl = 'http://example.com';
-       ok(! system(@command, "-url=$baseurl", q{--rebuild}));
+       ok(! system(@command, "--url=$baseurl", q{--rebuild}));
 
        $html = "$tmp/out/pianopost/index.html";
        ($href) = _extract_html_links($html, 'piano');
        is($href, "$baseurl/piano.mp3",
-               q{html enclosure with -url is fully absolute});
+               q{html enclosure with --url is fully absolute});
 
        $html = "$tmp/out/attempted_multiple_enclosures/index.html";
        ($href) = _extract_html_links($html, 'walter');
        is($href, "$baseurl/walter.ogg",
-               q{html enclosure with -url is fully absolute});
+               q{html enclosure with --url is fully absolute});
 
        ok(! system("rm -rf $tmp $statedir"), q{teardown});
 }
 
 sub inlined_pages_html {
-       my @command = (qw(./ikiwiki.out -plugin inline));
-       push @command, qw(-underlaydir=underlays/basewiki);
-       push @command, qw(-set underlaydirbase=underlays -templatedir=templates);
+       my @command = (@base_command, qw(--plugin inline));
        push @command, qw(t/tinypodcast), "$tmp/out";
 
+       ok(! system("rm -rf $tmp $statedir"), q{setup});
+
        ok(! system("mkdir $tmp"),
                q{setup});
        ok(! system(@command),
@@ -179,10 +192,10 @@ sub inlined_pages_html {
                q{html enclosure});
        my ($href) = _extract_html_links($html, 'piano.mp3');
        is($href, '/piano.mp3',
-               q{html enclosure from pianopost sans -url});
+               q{html enclosure from pianopost sans --url});
        ($href) = _extract_html_links($html, 'walter.ogg');
        is($href, '/walter.ogg',
-               q{html enclosure from attempted_multiple_enclosures sans -url});
+               q{html enclosure from attempted_multiple_enclosures sans --url});
 
        ok(! system("rm -rf $tmp $statedir"), q{teardown});
 }
@@ -231,3 +244,5 @@ podcast('simple');
 single_page_html();
 inlined_pages_html();
 podcast('fancy');
+
+done_testing;