r22341 - in /branches/upstream/libhtml-wikiconverter-phpwiki-perl: ./ current/ current/lib/ current/lib/HTML/ current/lib/HTML/WikiConverter/ current/t/

js at users.alioth.debian.org js at users.alioth.debian.org
Sat Jun 28 21:50:45 UTC 2008


Author: js
Date: Sat Jun 28 21:50:45 2008
New Revision: 22341

URL: http://svn.debian.org/wsvn/?sc=1&rev=22341
Log:
[svn-inject] Installing original source of libhtml-wikiconverter-phpwiki-perl

Added:
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/Changes
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/MANIFEST
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/META.yml
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/Makefile.PL
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/README
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/lib/
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/lib/HTML/
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/lib/HTML/WikiConverter/
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/lib/HTML/WikiConverter/PhpWiki.pm
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/00-load.t
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/boilerplate.t
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/phpwiki.t
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/pod-coverage.t
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/pod.t
    branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/runtests.pl

Added: branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/Changes
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/Changes?rev=22341&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/Changes (added)
+++ branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/Changes Sat Jun 28 21:50:45 2008
@@ -1,0 +1,11 @@
+# Change log for HTML::WikiConverter::PhpWiki
+
+version: 0.51
+date:    Wed June 07 15:00:00 EST 2006
+changes:
+  - (bug 17550) "<br><br>" now becomes "%%% %%%"
+
+version: 0.50
+date:    Tue Jan 10 2006
+changes:
+  - Branched from main HTML::WikiConverter codebase.

Added: branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/MANIFEST
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/MANIFEST?rev=22341&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/MANIFEST (added)
+++ branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/MANIFEST Sat Jun 28 21:50:45 2008
@@ -1,0 +1,12 @@
+Changes
+MANIFEST
+META.yml # Will be created by "make dist"
+Makefile.PL
+README
+lib/HTML/WikiConverter/PhpWiki.pm
+t/00-load.t
+t/boilerplate.t
+t/phpwiki.t
+t/pod-coverage.t
+t/pod.t
+t/runtests.pl

Added: branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/META.yml
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/META.yml?rev=22341&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/META.yml (added)
+++ branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/META.yml Sat Jun 28 21:50:45 2008
@@ -1,0 +1,12 @@
+# http://module-build.sourceforge.net/META-spec.html
+#XXXXXXX This is a prototype!!!  It will change in the future!!! XXXXX#
+name:         HTML-WikiConverter-PhpWiki
+version:      0.51
+version_from: lib/HTML/WikiConverter/PhpWiki.pm
+installdirs:  site
+requires:
+    HTML::WikiConverter:           0.52
+    Test::More:                    0
+
+distribution_type: module
+generated_by: ExtUtils::MakeMaker version 6.17

Added: branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/Makefile.PL
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/Makefile.PL?rev=22341&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/Makefile.PL (added)
+++ branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/Makefile.PL Sat Jun 28 21:50:45 2008
@@ -1,0 +1,17 @@
+use strict;
+use warnings;
+use ExtUtils::MakeMaker;
+
+WriteMakefile(
+    NAME                => 'HTML::WikiConverter::PhpWiki',
+    AUTHOR              => 'David J. Iberri <diberri at cpan.org>',
+    VERSION_FROM        => 'lib/HTML/WikiConverter/PhpWiki.pm',
+    ABSTRACT_FROM       => 'lib/HTML/WikiConverter/PhpWiki.pm',
+    PL_FILES            => {},
+    PREREQ_PM => {
+        'Test::More' => 0,
+        'HTML::WikiConverter' => 0.52,
+    },
+    dist                => { COMPRESS => 'gzip -9f', SUFFIX => 'gz', },
+    clean               => { FILES => 'HTML-WikiConverter-PhpWiki-*' },
+);

Added: branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/README
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/README?rev=22341&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/README (added)
+++ branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/README Sat Jun 28 21:50:45 2008
@@ -1,0 +1,66 @@
+HTML::WikiConverter::PhpWiki
+============================
+
+HTML::WikiConverter::PhpWiki adds the PhpWiki dialect to
+HTML::WikiConverter allowing the conversion of HTML to PhpWiki markup.
+
+SYNOPSIS
+
+Converting HTML to wiki markup is easy:
+
+  use HTML::WikiConverter;
+  my $wc = new HTML::WikiConverter( dialect => 'PhpWiki' );
+  print $wc->html2wiki( $html );
+
+Or from the command line:
+
+  % html2wiki --dialect PhpWiki input.html > output.wiki
+
+There's also a web interface if you're so inclined:
+
+  http://diberri.dyndns.org/html2wiki.html
+
+CHANGES IN 0.51
+
+  * (bug #17550) "<br><br>" now becomes "%%% %%%"
+
+DEPENDENCIES
+
+  * HTML::WikiConverter version 0.52
+
+INSTALLATION
+
+To install this module, run the following commands:
+
+    perl Makefile.PL
+    make
+    make test
+    make install
+
+SUPPORT AND DOCUMENTATION
+
+After installing, you can find documentation for this module with the
+perldoc command.
+
+    perldoc HTML::WikiConverter::PhpWiki
+
+You can also look for information at:
+
+    Search CPAN
+        http://search.cpan.org/dist/HTML-WikiConverter-PhpWiki
+
+    CPAN Request Tracker:
+        http://rt.cpan.org/NoAuth/Bugs.html?Dist=HTML-WikiConverter-PhpWiki
+
+    AnnoCPAN, annotated CPAN documentation:
+        http://annocpan.org/dist/HTML-WikiConverter-PhpWiki
+
+    CPAN Ratings:
+        http://cpanratings.perl.org/d/HTML-WikiConverter-PhpWiki
+
+COPYRIGHT AND LICENCE
+
+Copyright (C) 2006 David J. Iberri
+
+This program is free software; you can redistribute it and/or modify
+it under the same terms as Perl itself.

Added: branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/lib/HTML/WikiConverter/PhpWiki.pm
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/lib/HTML/WikiConverter/PhpWiki.pm?rev=22341&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/lib/HTML/WikiConverter/PhpWiki.pm (added)
+++ branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/lib/HTML/WikiConverter/PhpWiki.pm Sat Jun 28 21:50:45 2008
@@ -1,0 +1,174 @@
+package HTML::WikiConverter::PhpWiki;
+
+use warnings;
+use strict;
+
+use base 'HTML::WikiConverter';
+
+our $VERSION = '0.51';
+
+=head1 NAME
+
+HTML::WikiConverter::PhpWiki - Convert HTML to PhpWiki markup
+
+=head1 SYNOPSIS
+
+  use HTML::WikiConverter;
+  my $wc = new HTML::WikiConverter( dialect => 'PhpWiki' );
+  print $wc->html2wiki( $html );
+
+=head1 DESCRIPTION
+
+This module contains rules for converting HTML into PhpWiki
+markup. See L<HTML::WikiConverter> for additional usage details.
+
+=cut
+
+sub rules {
+  my %rules = (
+    hr => { replace => "\n----\n" },
+    br => { replace => '%%%' },
+
+    blockquote => { start => \&_blockquote_start, block => 1, line_format => 'multi' },
+    p => { block => 1, trim => 'both', line_format => 'multi' },
+    i => { start => "_", end => "_" },
+    em => { alias => 'i' },
+    b => { start => "*", end => "*" },
+    strong => { alias => 'b' },
+
+    img => { replace => \&_image },
+    a => { replace => \&_link },
+
+    ul => { line_format => 'multi', block => 1 },
+    ol => { alias => 'ul' },
+    dl => { line_format => 'blocks', block => 1 },
+
+    li => { start => \&_li_start, trim => 'leading' },
+    dt => { trim => 'both', end => ":\n" },
+    dd => { line_prefix => '  ' },
+
+    td => { start => \&_td_start, end => \&_td_end, trim => 'both' },
+    th => { alias => 'td' },
+
+    h1 => { start => '!!! ', block => 1, trim => 'both', line_format => 'single' },
+    h2 => { start => '!!! ', block => 1, trim => 'both', line_format => 'single' },
+    h3 => { start => '!! ',  block => 1, trim => 'both', line_format => 'single' },
+    h4 => { start => '! ',   block => 1, trim => 'both', line_format => 'single' },
+    h5 => { start => '! ',   block => 1, trim => 'both', line_format => 'single' },
+    h6 => { start => '! ',   block => 1, trim => 'both', line_format => 'single' },
+
+    pre => { preserve => 1 },
+  );
+
+  $rules{$_} = { preserve => 1 } for qw/ big small tt abbr acronym cite code dfn kbd samp var sup sub /;
+  return \%rules;
+}
+
+# Calculates the prefix that will be placed before each list item.
+# List item include ordered and unordered list items.
+sub _li_start {
+  my( $self, $node, $rules ) = @_;
+  my @parent_lists = $node->look_up( _tag => qr/ul|ol/ );
+  my $depth = @parent_lists;
+
+  my $bullet = '';
+  $bullet = '*' if $node->parent->tag eq 'ul';
+  $bullet = '#' if $node->parent->tag eq 'ol';
+
+  my $prefix = ( $bullet ) x $depth;
+  return "\n$prefix ";
+}
+
+sub _image {
+  my( $self, $node, $rules ) = @_;
+  return $node->attr('src') || '';
+}
+
+sub _link {
+  my( $self, $node, $rules ) = @_;
+  my $url = $node->attr('href') || '';
+  my $text = $self->get_elem_contents($node) || '';
+  return "[$text|$url]";
+}
+
+# XXX doesn't handle rowspan
+sub _td_start {
+  my( $self, $node, $rules ) = @_;
+  my @left = $node->left;
+  return '' unless @left;
+  return ( ( '  ' ) x scalar(@left) );
+}
+
+sub _td_end {
+  my( $self, $node, $rules ) = @_;
+  my $right_tag = $node->right && $node->right->tag ? $node->right->tag : '';
+  return $right_tag =~ /td|th/ ? " |\n" : "\n";
+}
+
+sub _blockquote_start {
+  my( $self, $node, $rules ) = @_;
+  my @bq_lineage = $node->look_up( _tag => 'blockquote' );
+  my $depth = @bq_lineage;
+  return "\n" . ( ( '  ' ) x $depth );
+}
+
+sub preprocess_node {
+  my( $self, $node ) = @_;
+  $self->strip_aname($node) if $node->tag eq 'a';
+  $self->caption2para($node) if $node->tag eq 'caption';
+
+  # Bug 17550 (https://rt.cpan.org/Public/Bug/Display.html?id=17550)
+  $node->postinsert(' ') if $node->tag eq 'br' and $node->right and $node->right->tag eq 'br';
+}
+
+=head1 AUTHOR
+
+David J. Iberri, C<< <diberri at cpan.org> >>
+
+=head1 BUGS
+
+Please report any bugs or feature requests to
+C<bug-html-wikiconverter-phpwiki at rt.cpan.org>, or through the web
+interface at
+L<http://rt.cpan.org/NoAuth/ReportBug.html?Queue=HTML-WikiConverter-PhpWiki>.
+I will be notified, and then you'll automatically be notified of
+progress on your bug as I make changes.
+
+=head1 SUPPORT
+
+You can find documentation for this module with the perldoc command.
+
+    perldoc HTML::WikiConverter::PhpWiki
+
+You can also look for information at:
+
+=over 4
+
+=item * AnnoCPAN: Annotated CPAN documentation
+
+L<http://annocpan.org/dist/HTML-WikiConverter-PhpWiki>
+
+=item * CPAN Ratings
+
+L<http://cpanratings.perl.org/d/HTML-WikiConverter-PhpWiki>
+
+=item * RT: CPAN's request tracker
+
+L<http://rt.cpan.org/NoAuth/Bugs.html?Dist=HTML-WikiConverter-PhpWiki>
+
+=item * Search CPAN
+
+L<http://search.cpan.org/dist/HTML-WikiConverter-PhpWiki>
+
+=back
+
+=head1 COPYRIGHT & LICENSE
+
+Copyright 2006 David J. Iberri, all rights reserved.
+
+This program is free software; you can redistribute it and/or modify
+it under the same terms as Perl itself.
+
+=cut
+
+1;

Added: branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/00-load.t
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/00-load.t?rev=22341&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/00-load.t (added)
+++ branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/00-load.t Sat Jun 28 21:50:45 2008
@@ -1,0 +1,9 @@
+#!perl -T
+
+use Test::More tests => 1;
+
+BEGIN {
+	use_ok( 'HTML::WikiConverter::PhpWiki' );
+}
+
+diag( "Testing HTML::WikiConverter::PhpWiki $HTML::WikiConverter::PhpWiki::VERSION, Perl $], $^X" );

Added: branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/boilerplate.t
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/boilerplate.t?rev=22341&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/boilerplate.t (added)
+++ branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/boilerplate.t Sat Jun 28 21:50:45 2008
@@ -1,0 +1,48 @@
+#!perl -T
+
+use strict;
+use warnings;
+use Test::More tests => 3;
+
+sub not_in_file_ok {
+    my ($filename, %regex) = @_;
+    open my $fh, "<", $filename
+        or die "couldn't open $filename for reading: $!";
+
+    my %violated;
+
+    while (my $line = <$fh>) {
+        while (my ($desc, $regex) = each %regex) {
+            if ($line =~ $regex) {
+                push @{$violated{$desc}||=[]}, $.;
+            }
+        }
+    }
+
+    if (%violated) {
+        fail("$filename contains boilerplate text");
+        diag "$_ appears on lines @{$violated{$_}}" for keys %violated;
+    } else {
+        pass("$filename contains no boilerplate text");
+    }
+}
+
+not_in_file_ok(README =>
+    "The README is used..."       => qr/The README is used/,
+    "'version information here'"  => qr/to provide version information/,
+);
+
+not_in_file_ok(Changes =>
+    "placeholder date/time"       => qr(Date/time)
+);
+
+sub module_boilerplate_ok {
+    my ($module) = @_;
+    not_in_file_ok($module =>
+        'the great new $MODULENAME'   => qr/ - The great new /,
+        'boilerplate description'     => qr/Quick summary of what the module/,
+        'stub function definition'    => qr/function[12]/,
+    );
+}
+
+module_boilerplate_ok('lib/HTML/WikiConverter/PhpWiki.pm');

Added: branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/phpwiki.t
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/phpwiki.t?rev=22341&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/phpwiki.t (added)
+++ branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/phpwiki.t Sat Jun 28 21:50:45 2008
@@ -1,0 +1,290 @@
+local $/;
+require 't/runtests.pl';
+runtests( data => <DATA>, dialect => 'PhpWiki' );
+close DATA;
+
+__DATA__
+pre
+__H__
+<html>
+<pre>
+Device ID                 : 0
+Device Revision           : 0
+Firmware Revision         : 1.71
+IPMI Version              : 1.0
+Manufacturer ID           : 674
+Product ID                : 1 (0x0001)
+Device Available          : yes
+Provides Device SDRs      : yes
+Additional Device Support :
+    Sensor Device
+    SDR Repository Device
+    SEL Device
+    FRU Inventory Device
+    IPMB Event Receiver
+Aux Firmware Rev Info     :
+    0x00
+    0x00
+    0x00
+    0x00
+</pre>
+</html>
+__W__
+<pre>
+Device ID                 : 0
+Device Revision           : 0
+Firmware Revision         : 1.71
+IPMI Version              : 1.0
+Manufacturer ID           : 674
+Product ID                : 1 (0x0001)
+Device Available          : yes
+Provides Device SDRs      : yes
+Additional Device Support :
+    Sensor Device
+    SDR Repository Device
+    SEL Device
+    FRU Inventory Device
+    IPMB Event Receiver
+Aux Firmware Rev Info     :
+    0x00
+    0x00
+    0x00
+    0x00
+</pre>
+__NEXT__
+bold
+__H__
+<html><b>bold</b></html>
+__W__
+*bold*
+__NEXT__
+italics
+__H__
+<html><i>italics</i></html>
+__W__
+_italics_
+__NEXT__
+bold and italics
+__H__
+<html><b>bold</b> and <i>italics</i></html>
+__W__
+*bold* and _italics_
+__NEXT__
+bold-italics nested
+__H__
+<html><i><b>bold-italics</b> nested</i></html>
+__W__
+_*bold-italics* nested_
+__NEXT__
+strong
+__H__
+<html><strong>strong</strong></html>
+__W__
+*strong*
+__NEXT__
+emphasized
+__H__
+<html><em>emphasized</em></html>
+__W__
+_emphasized_
+__NEXT__
+one-line phrasals
+__H__
+<html><i>phrasals
+in one line</i></html>
+__W__
+_phrasals in one line_
+__NEXT__
+paragraph blocking
+__H__
+<html><p>p1</p><p>p2</p></html>
+__W__
+p1
+
+p2
+__NEXT__
+lists
+__H__
+<html><ul><li>1</li><li>2</li></ul></html>
+__W__
+* 1
+* 2
+__NEXT__
+nested lists
+__H__
+<html><ul><li>1<ul><li>1a</li><li>1b</li></ul></li><li>2</li></ul>
+__W__
+* 1
+** 1a
+** 1b
+* 2
+__NEXT__
+nested lists (different types)
+__H__
+<html><ul><li>1<ul><li>a<ol><li>i</li></ol></li><li>b</li></ul></li><li>2</li></ul></html>
+__W__
+* 1
+** a
+### i
+** b
+* 2
+__NEXT__
+hr
+__H__
+<html><hr /></html>
+__W__
+----
+__NEXT__
+br
+__H__
+<html><p>stuff<br />stuff two</p></html>
+__W__
+stuff%%%stuff two
+__NEXT__
+sub
+__H__
+<html><p>H<sub>2</sub>O</p></html>
+__W__
+H<sub>2</sub>O
+__NEXT__
+sup
+__H__
+<html><p>x<sup>2</sup></p></html>
+__W__
+x<sup>2</sup>
+__NEXT__
+small
+__H__
+<html><small>small text</small></html>
+__W__
+<small>small text</small>
+__NEXT__
+big
+__H__
+<html><big>big text</big></html>
+__W__
+<big>big text</big>
+__NEXT__
+code
+__H__
+<html><code>$name = 'stan';</code></html>
+__W__
+<code>$name = 'stan';</code>
+__NEXT__
+tt
+__H__
+<html><tt>tt text</tt></html>
+__W__
+<tt>tt text</tt>
+__NEXT__
+pre
+__H__
+<html><pre>this
+  is
+    preformatted
+      text</pre></html>
+__W__
+<pre>this
+  is
+    preformatted
+      text</pre>
+__NEXT__
+indent
+__H__
+<html><blockquote>indented text</blockquote></html>
+__W__
+  indented text
+__NEXT__
+nested indent
+__H__
+<html><blockquote>indented text <blockquote>double-indented</blockquote></blockquote></html>
+__W__
+  indented text
+    double-indented
+__NEXT__
+h1
+__H__
+<h1>h1</h1>
+__W__
+!!! h1
+__NEXT__
+h2
+__H__
+<h2>h2</h2>
+__W__
+!!! h2
+__NEXT__
+h3
+__H__
+<h3>h3</h3>
+__W__
+!! h3
+__NEXT__
+h4
+__H__
+<h4>h4</h4>
+__W__
+! h4
+__NEXT__
+h5
+__H__
+<h5>h5</h5>
+__W__
+! h5
+__NEXT__
+h6
+__H__
+<h6>h6</h6>
+__W__
+! h6
+__NEXT__
+img
+__H__
+<html><img src="thing.gif" /></html>
+__W__
+http://www.test.com/thing.gif
+__NEXT__
+external links
+__H__
+<html><a href="test.html">thing</a></html>
+__W__
+[thing|http://www.test.com/test.html]
+__NEXT__
+definition lists
+__H__
+<html><dl><dt>Some term</dt><dd><p>Embedded <i>formatting</i> is fun<sup>2</sup>!</p><p>Another <strong>formatted</strong> paragraph.</p></dd></dl></html>
+__W__
+Some term:
+
+  Embedded _formatting_ is fun<sup>2</sup>!
+
+  Another *formatted* paragraph.
+__NEXT__
+simple tables
+__H__
+<html>
+  <table>
+    <tr>
+      <td> Name </td>
+      <td> David </td></tr><tr><td> Age </td>
+      <td> 24 </td>
+    </tr>
+  </table>
+</html>
+__W__
+Name |
+  David
+Age |
+  24
+__NEXT__
+brbr
+__H__
+<br><br>
+__W__
+%%% %%%
+__NEXT__
+brbrbr
+__H__
+<br><br><br>
+__W__
+%%% %%% %%%

Added: branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/pod-coverage.t
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/pod-coverage.t?rev=22341&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/pod-coverage.t (added)
+++ branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/pod-coverage.t Sat Jun 28 21:50:45 2008
@@ -1,0 +1,22 @@
+#!perl -T
+
+use Test::More;
+eval "use Test::Pod::Coverage 1.04";
+plan skip_all => "Test::Pod::Coverage 1.04 required for testing POD coverage" if $@;
+all_pod_coverage_ok( { also_private => [
+  # These methods are documented in HTML::WikiConverter::Dialects
+  qr/
+     get_elem_contents
+    |get_wiki_page
+    |get_attr_str
+    |is_camel_case
+    |rule
+    |rules
+    |attribute
+    |attributes
+    |preprocess_node
+    |postprocess_output
+    |caption2para
+    |strip_aname
+  /x
+] } );

Added: branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/pod.t
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/pod.t?rev=22341&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/pod.t (added)
+++ branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/pod.t Sat Jun 28 21:50:45 2008
@@ -1,0 +1,6 @@
+#!perl -T
+
+use Test::More;
+eval "use Test::Pod 1.14";
+plan skip_all => "Test::Pod 1.14 required for testing POD" if $@;
+all_pod_files_ok();

Added: branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/runtests.pl
URL: http://svn.debian.org/wsvn/branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/runtests.pl?rev=22341&op=file
==============================================================================
--- branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/runtests.pl (added)
+++ branches/upstream/libhtml-wikiconverter-phpwiki-perl/current/t/runtests.pl Sat Jun 28 21:50:45 2008
@@ -1,0 +1,132 @@
+#!/usr/bin/perl
+use warnings;
+use strict;
+
+use Test::More;
+use File::Spec;
+use HTML::Entities;
+use HTML::WikiConverter;
+*e = \&encode_entities;
+
+my $more_tests = <<END_TESTS;
+__NEXT__
+entities (1)
+__H__
+To enter a '&lt;' in your input, use "&amp;lt;"
+__W__
+To enter a '&lt;' in your input, use "&amp;lt;"
+__NEXT__
+entities (2)
+__H__
+To enter a '<' in your input, use "&amp;lt;"
+__W__
+To enter a '&lt;' in your input, use "&amp;lt;"
+__NEXT__
+strip comments
+__H__
+A <!-- stripped --> comment
+__W__
+A  comment
+__NEXT__
+strip head
+__H__
+<html>
+<head><title>fun stuff</title></head>
+<body>
+<p>Crazy stuff here</p>
+</body>
+</html>
+__W__
+Crazy stuff here
+__NEXT__
+strip scripts
+__H__
+<html>
+<head><script>bogus stuff</script></head>
+<body>
+<script>maliciousCode()</script>
+<p>benevolent text</p>
+</body>
+</html>
+__W__
+benevolent text
+END_TESTS
+
+sub runtests {
+  my %arg = @_;
+
+  $arg{wrap_in_html} = 1;
+  $arg{base_uri} ||= 'http://www.test.com';
+  my $minimal = $arg{minimal} || 0;
+
+  my $data = $arg{data} || '';
+  $data .= entity_tests() . $more_tests unless $minimal;
+
+  my @tests = split /__NEXT__\n/, $data;
+  my $numtests = @tests;
+  #$numtests += 1 unless $minimal; # file test
+  plan tests => $numtests;
+
+  # Delete unrecognized HTML::WikiConverter options
+  delete $arg{$_} for qw/ data minimal /;
+
+  my $wc = new HTML::WikiConverter(%arg);
+  foreach my $test ( @tests ) {
+    $test =~ s/^(.*?)\n//; my $name = $1;
+    my( $html, $wiki ) = split /__W__\n/, $test;
+    $html =~ s/__H__\n//;
+
+    $name =~ s{\s*\:\:(\w+\([^\)]*?\))}{
+      my $method_call = $1;
+      eval "\$wc->$method_call;";
+      die "Failed test call ($name): $@" if $@;
+      '';
+    }ge;
+
+    for( $html, $wiki ) { s/^\n+//; s/\n+$// }
+    is( $wc->html2wiki($html), $wiki, $name );
+  }
+
+  #file_test($wc) unless $minimal;
+}
+
+sub entity_tests {
+  my $tmpl = "__NEXT__\n%s\n__H__\n%s\n__W__\n%s\n"; # test-name, html-input, expected-wiki-output
+
+  my $data = '';
+  my @chars = ( '<', '>', '&' );
+  foreach my $char ( @chars ) {
+    ( my $charname = e($char) ) =~ s/[&;]//g;
+    $data .= sprintf $tmpl, "literal ($charname)", $char, e($char)
+          .  sprintf $tmpl, "encode ($charname)", e($char), e($char)
+          .  sprintf $tmpl, "meta ($charname)", e(e($char)), e(e($char));
+  }
+
+  return $data;
+}
+
+sub _slurp {
+  my $path = shift;
+  open H, $path or die "couldn't open $path: $!";
+  local $/;
+  my $c = <H>;
+  close H;
+  return $c;
+}
+
+sub file_test {
+  my $wc = shift;
+  my $lc_dialect = lc $wc->dialect;
+  my $infile = File::Spec->catfile( 't', 'complete.html' );
+  my $outfile = File::Spec->catfile( 't', "complete.$lc_dialect" );
+
+  SKIP: {
+    skip "Couldn't find $infile (ignore this)", 1 unless -e $infile;
+    skip "Couldn't find $outfile (ignore this)", 1 unless -e $outfile;
+    my( $got, $expect ) = ( $wc->html2wiki( file => $infile, slurp => 1 ), _slurp($outfile) );
+    for( $got, $expect ) { s/^\n+//; s/\n+$// }
+    is( $got, $expect, 'read from file' );
+  };
+}
+
+1;




More information about the Pkg-perl-cvs-commits mailing list