X-Git-Url: http://git.vanrenterghem.biz/git.ikiwiki.info.git/blobdiff_plain/116f206aea1203f426d074151ea6a73a13c0155b..b6a327d99339bde3638ef25ebcf4e1f49f7545b0:/t/podcast.t

diff --git a/t/podcast.t b/t/podcast.t
index 50493aff6..f036c3113 100755
--- a/t/podcast.t
+++ b/t/podcast.t
@@ -3,54 +3,231 @@ use warnings;
 use strict;
 
 BEGIN {
-	eval q{use XML::Feed};
+	eval q{use XML::Feed; use HTML::Parser; use HTML::LinkExtor; use File::MimeInfo};
 	if ($@) {
-		eval q{use Test::More skip_all => "XML::Feed not available"};
+		eval q{use Test::More skip_all =>
+			"XML::Feed and/or HTML::Parser or File::MimeInfo not available"};
 	}
 	else {
-		eval q{use Test::More tests => 36};
+		eval q{use Test::More tests => 136};
 	}
 }
 
-sub simple_podcast {
+use Cwd;
+use File::Basename;
+
+my $tmp = 't/tmp';
+my $statedir = 't/tinypodcast/.ikiwiki';
+
+sub podcast {
+	my $podcast_style = shift;
+
 	my $baseurl = 'http://example.com';
-	ok(! system("mkdir t/tmp"));
-	ok(! system("./ikiwiki.out -plugin inline -url=$baseurl -rss -atom -underlaydir=underlays/basewiki -set underlaydirbase=underlays -templatedir=templates t/tinypodcast t/tmp/out"));
+	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";
+
+	ok(! system("mkdir $tmp"),
+		q{setup});
+	ok(! system(@command),
+		q{build});
 
 	my %media_types = (
+		'simplepost'	=> undef,
 		'piano.mp3'	=> 'audio/mpeg',
 		'scroll.3gp'	=> 'video/3gpp',
 		'walter.ogg'	=> 'video/x-theora+ogg',
 	);
 
 	for my $format (qw(atom rss)) {
-		my $feed = XML::Feed->parse("t/tmp/out/index.$format");
+		my $feed = XML::Feed->parse("$tmp/out/$podcast_style/index.$format");
 
-		is($feed->title, 'wiki', qq{$format feed title});
-		is($feed->link, "$baseurl/", qq{$format feed link});
-		is($feed->description, $feed->title, qq{$format feed description});
+		is($feed->title, $podcast_style,
+			qq{$format feed title});
+		is($feed->link, "$baseurl/$podcast_style/",
+			qq{$format feed link});
+		is($feed->description, 'wiki',
+			qq{$format feed description});
 		if ('atom' eq $format) {
-			is($feed->author, $feed->title, qq{$format feed author});
-			is($feed->id, "$baseurl/", qq{$format feed id});
-			is($feed->generator, "ikiwiki", qq{$format feed generator});
+			is($feed->author, $feed->description,
+				qq{$format feed author});
+			is($feed->id, $feed->link,
+				qq{$format feed id});
+			is($feed->generator, "ikiwiki",
+				qq{$format feed generator});
 		}
 
 		for my $entry ($feed->entries) {
 			my $title = $entry->title;
 			my $url = $entry->id;
+			my $body = $entry->content->body;
 			my $enclosure = $entry->enclosure;
 
-			is($url, "$baseurl/$title", qq{$format $title id});
 			is($entry->link, $url, qq{$format $title link});
-			is($enclosure->url, $url, qq{$format $title enclosure url});
-			is($enclosure->type, $media_types{$title}, qq{$format $title enclosure type});
-			# is($enclosure->length, '12345', qq{$format $title enclosure length});
-			# creation date
-			# modification date
+			isnt($entry->issued, undef,
+				qq{$format $title issued date});
+			isnt($entry->modified, undef,
+				qq{$format $title modified date});
+
+			if (defined $media_types{$title}) {
+				is($url, "$baseurl/$title",
+					qq{$format $title id});
+				is($body, undef,
+					qq{$format $title no body text});
+				is($enclosure->url, $url,
+					qq{$format $title enclosure url});
+				is($enclosure->type, $media_types{$title},
+					qq{$format $title enclosure type});
+				cmp_ok($enclosure->length, '>', 0,
+					qq{$format $title enclosure length});
+			}
+			else {
+				# XXX hack hack hack
+				my $expected_id = "$baseurl/$title/";
+				$expected_id =~ s/\ /_/g;
+
+				is($url, $expected_id,
+					qq{$format $title id});
+				isnt($body, undef,
+					qq{$format $title body text});
+
+				if ('fancy' eq $podcast_style) {
+					isnt($enclosure, undef,
+						qq{$format $title enclosure});
+					my $filename = basename($enclosure->url);
+					is($enclosure->type, $media_types{$filename},
+						qq{$format $title enclosure type});
+					cmp_ok($enclosure->length, '>', 0,
+						qq{$format $title enclosure length});
+				}
+				else {
+					is($enclosure, undef,
+						qq{$format $title no enclosure});
+				}
+			}
 		}
 	}
 
-	ok(! system("rm -rf t/tmp t/tinypodcast/.ikiwiki"));
+	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);
+	push @command, qw(t/tinypodcast), "$tmp/out";
+
+	ok(! system("mkdir $tmp"),
+		q{setup});
+	ok(! system(@command),
+		q{build});
+
+	my $html = "$tmp/out/pianopost/index.html";
+	like(_extract_html_content($html, 'content'), qr/has content and/m,
+		q{html body text});
+	like(_extract_html_content($html, 'enclosure'), qr/Download/m,
+		q{html enclosure});
+	my ($href) = _extract_html_links($html, 'piano');
+	is($href, '/piano.mp3',
+		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,
+		q{html body text});
+	like(_extract_html_content($html, 'enclosure'), qr/Download/m,
+		q{html enclosure});
+	($href) = _extract_html_links($html, 'walter');
+	is($href, '/walter.ogg',
+		q{html enclosure sans -url is site-absolute});
+
+	my $baseurl = 'http://example.com';
+	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});
+
+	$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});
+
+	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);
+	push @command, qw(t/tinypodcast), "$tmp/out";
+
+	ok(! system("mkdir $tmp"),
+		q{setup});
+	ok(! system(@command),
+		q{build});
+
+	my $html = "$tmp/out/fancy/index.html";
+	my $contents = _extract_html_content($html, 'content');
+	like($contents, qr/has content and an/m,
+		q{html body text from pianopost});
+	like($contents, qr/has content and only one/m,
+		q{html body text from attempted_multiple_enclosures});
+	my $enclosures = _extract_html_content($html, 'inlineenclosure');
+	like($enclosures, qr/Download/m,
+		q{html enclosure});
+	my ($href) = _extract_html_links($html, 'piano.mp3');
+	is($href, '/piano.mp3',
+		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});
+
+	ok(! system("rm -rf $tmp $statedir"), q{teardown});
+}
+
+sub _extract_html_content {
+	my ($file, $desired_id, $desired_tag) = @_;
+	$desired_tag = 'div' unless defined $desired_tag;
+
+	my $p = HTML::Parser->new(api_version => 3);
+	my $content = '';
+
+	$p->handler(start => sub {
+		my ($tag, $self, $attr) = @_;
+		return if $tag ne $desired_tag;
+		return unless exists $attr->{id} && $attr->{id} eq $desired_id;
+
+		$self->handler(text => sub {
+			my ($dtext) = @_;
+			$content .= $dtext;
+		}, "dtext");
+	}, "tagname,self,attr");
+
+	$p->parse_file($file) || die $!;
+
+	return $content;
+}
+
+sub _extract_html_links {
+	my ($file, $desired_value) = @_;
+
+	my @hrefs = ();
+
+	my $p = HTML::LinkExtor->new(sub {
+		my ($tag, %attr) = @_;
+		return if $tag ne 'a';
+		return unless $attr{href} =~ qr/$desired_value/;
+		push(@hrefs, values %attr);
+	}, getcwd() . '/' . $file);
+
+	$p->parse_file($file);
+
+	return @hrefs;
 }
 
-simple_podcast();
+podcast('simple');
+single_page_html();
+inlined_pages_html();
+podcast('fancy');