From 0202ee945a19bcb6e497f0200f096de16db845f4 Mon Sep 17 00:00:00 2001 From: dakkar Date: Sun, 5 Feb 2006 13:45:32 +0000 Subject: step per parsare ReST in un dom XML git-svn-id: svn://luxion/repos/WebCoso/trunk@154 fcb26f47-9200-0410-b104-b98ab5b095f3 --- t/steps/rest-xml.t | 99 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 99 insertions(+) create mode 100644 t/steps/rest-xml.t (limited to 't') diff --git a/t/steps/rest-xml.t b/t/steps/rest-xml.t new file mode 100644 index 0000000..6ee8fa2 --- /dev/null +++ b/t/steps/rest-xml.t @@ -0,0 +1,99 @@ +#!/usr/bin/perl +use utf8; +use strict; +use warnings; +use Path::Class; +use Test::More 'no_plan'; +use Test::Differences; +use Encode; +use WebCoso::Resource; + +BEGIN {use_ok('WebCoso::Step::ReST::ToXml')} +my $step=WebCoso::Step::ReST::ToXml->new(); + +sub make_res { + my $resource=WebCoso::Resource->new(); + # serve solo per il path + $resource->set_property({filename=>'/tmp/mydoc.rest.txt'},datastream=>undef); + if (@_==1) { # monolingua + $resource->set_property(rstdoc=>$_[0]); + } + else { # multilingua + my %rst_doc=@_; + while (my ($lang,$str)=each %rst_doc) { + $resource->set_property( + {language=>$lang}, + rstdoc=>$str + ); + } + } + + return $resource; +} + +my $resource=make_res(<<'END_REST'); +Documento +========= + +paragrafo àè +END_REST + +$step->process($resource,'gen'); +ok(!defined $resource->get_property('xmldom'),'no action on second pass'); + +$step->process($resource,'meta'); +my $dom=$resource->get_property('xmldom'); +isa_ok($dom,'XML::LibXML::Document','parsed ok on first pass'); + +is($dom->findvalue('/document/@source'), + '/tmp/mydoc.rest.txt', + 'source path'); +is($dom->findvalue('/document/title'), + 'Documento', + 'title'); +is($dom->findvalue('count(/document/paragraph)'), + 1, + '1 paragraph'); +is($dom->findvalue('/document/paragraph'), + 'paragrafo àè', + 'paragraph content (unicode)'); + +$resource=make_res(it=><<'END_REST_IT',en=><<'END_REST_EN'); +Documento +========= + +paragrafo +END_REST_IT +Document +======== + +paragraph +END_REST_EN + +$step->process($resource,'meta'); +$dom=$resource->get_property({language=>'it'},'xmldom'); +isa_ok($dom,'XML::LibXML::Document','parsed it'); + +is($dom->findvalue('/document/@source'), + '/tmp/mydoc.rest.txt', + 'source path'); +is($dom->findvalue('/document/title'), + 'Documento', + 'title'); +is($dom->findvalue('/document/paragraph'), + 'paragrafo', + 'paragraph content'); + +$dom=$resource->get_property({language=>'en'},'xmldom'); +isa_ok($dom,'XML::LibXML::Document','parsed en'); + +is($dom->findvalue('/document/@source'), + '/tmp/mydoc.rest.txt', + 'source path'); +is($dom->findvalue('/document/title'), + 'Document', + 'title'); +is($dom->findvalue('/document/paragraph'), + 'paragraph', + 'paragraph content'); + -- cgit v1.2.3