Document that podcasts are text XOR enclosure.
authorAmitai Schlair <schmonz-web-ikiwiki@schmonz.com>
Sun, 17 Feb 2013 15:52:23 +0000 (10:52 -0500)
committerAmitai Schlair <schmonz-web-ikiwiki@schmonz.com>
Sun, 17 Feb 2013 15:52:23 +0000 (10:52 -0500)
t/podcast.t
t/tinypodcast/index.mdwn
t/tinypodcast/post.mdwn [new file with mode: 0644]

index 4a5bde6a9c0165f7b01daac522cf52ba4989ca78..da91b34463c1f93cc1cb1f052d58e05e4a10c987 100755 (executable)
@@ -8,7 +8,7 @@ BEGIN {
                eval q{use Test::More skip_all => "XML::Feed not available"};
        }
        else {
                eval q{use Test::More skip_all => "XML::Feed not available"};
        }
        else {
-               eval q{use Test::More tests => 36};
+               eval q{use Test::More tests => 72};
        }
 }
 
        }
 }
 
@@ -23,6 +23,7 @@ sub simple_podcast {
        ok(! system(@command));
 
        my %media_types = (
        ok(! system(@command));
 
        my %media_types = (
+               'post'          => undef,
                'piano.mp3'     => 'audio/mpeg',
                'scroll.3gp'    => 'video/3gpp',
                'walter.ogg'    => 'video/x-theora+ogg',
                'piano.mp3'     => 'audio/mpeg',
                'scroll.3gp'    => 'video/3gpp',
                'walter.ogg'    => 'video/x-theora+ogg',
@@ -31,27 +32,53 @@ sub simple_podcast {
        for my $format (qw(atom rss)) {
                my $feed = XML::Feed->parse("t/tmp/out/index.$format");
 
        for my $format (qw(atom rss)) {
                my $feed = XML::Feed->parse("t/tmp/out/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, 'wiki',
+                       qq{$format feed title});
+               is($feed->link, "$baseurl/",
+                       qq{$format feed link});
+               is($feed->description, $feed->title,
+                       qq{$format feed description});
                if ('atom' eq $format) {
                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->title,
+                               qq{$format feed author});
+                       is($feed->id, "$baseurl/",
+                               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;
                }
 
                for my $entry ($feed->entries) {
                        my $title = $entry->title;
                        my $url = $entry->id;
+                       my $body = $entry->content->body;
                        my $enclosure = $entry->enclosure;
 
                        my $enclosure = $entry->enclosure;
 
-                       is($url, "$baseurl/$title", qq{$format $title id});
                        is($entry->link, $url, qq{$format $title link});
                        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 {
+                               is($url, "$baseurl/$title/",
+                                       qq{$format $title id});
+                               isnt($body, undef,
+                                       qq{$format $title body text});
+                               is($enclosure, undef,
+                                       qq{$format $title no enclosure});
+                       }
                }
        }
 
                }
        }
 
index a5c6c9bd83c063b5f7fa04dd3f3a52ece8f7a3da..530f7516ca076441a2b11fec9985e6df3fe79733 100644 (file)
@@ -1 +1 @@
-[[!inline pages="*.3gp or *.mov or *.mp3 or *.ogg" rss=yes atom=yes]]
+[[!inline pages="post or *.3gp or *.mov or *.mp3 or *.ogg" rss=yes atom=yes]]
diff --git a/t/tinypodcast/post.mdwn b/t/tinypodcast/post.mdwn
new file mode 100644 (file)
index 0000000..d28ddb5
--- /dev/null
@@ -0,0 +1 @@
+this article has content but no enclosure