# HG changeset patch # User cmlenz # Date 1161700071 0 # Node ID b592333efe1b56d4a529e2c77f56402979ec4795 # Parent caafc67d2d0fa246fe061cb011de69fa5cecf123 Improved the unit tests for nested namespaces in serialization. diff --git a/genshi/tests/output.py b/genshi/tests/output.py --- a/genshi/tests/output.py +++ b/genshi/tests/output.py @@ -15,7 +15,7 @@ import unittest import sys -from genshi.core import Stream +from genshi.core import Attrs, Stream, QName from genshi.input import HTML, XML from genshi.output import DocType, XMLSerializer, XHTMLSerializer, \ HTMLSerializer, EmptyTagFilter @@ -24,7 +24,7 @@ class XMLSerializerTestCase(unittest.TestCase): def test_doctype_in_stream(self): - stream = Stream([(Stream.DOCTYPE, DocType.HTML_STRICT, ('?', -1, -1))]) + stream = Stream([(Stream.DOCTYPE, DocType.HTML_STRICT, (None, -1, -1))]) output = stream.render(XMLSerializer) self.assertEqual('\n', output) def test_doctype_in_stream_no_pubid(self): - stream = Stream([(Stream.DOCTYPE, - ('html', None, 'http://www.w3.org/TR/html4/strict.dtd'), - ('?', -1, -1))]) + stream = Stream([ + (Stream.DOCTYPE, + ('html', None, 'http://www.w3.org/TR/html4/strict.dtd'), + (None, -1, -1)) + ]) output = stream.render(XMLSerializer) self.assertEqual('\n', @@ -50,7 +52,7 @@ def test_doctype_in_stream_no_pubid_or_sysid(self): stream = Stream([(Stream.DOCTYPE, ('html', None, None), - ('?', -1, -1))]) + (None, -1, -1))]) output = stream.render(XMLSerializer) self.assertEqual('\n', output) @@ -63,7 +65,9 @@ output) def test_doctype_one_and_only(self): - stream = Stream([(Stream.DOCTYPE, ('html', None, None), ('?', -1, -1))]) + stream = Stream([ + (Stream.DOCTYPE, ('html', None, None), (None, -1, -1)) + ]) output = stream.render(XMLSerializer, doctype=DocType.HTML_STRICT) self.assertEqual('', output) def test_processing_instruction(self): - stream = Stream([(Stream.PI, ('python', 'x = 2'), ('?', -1, -1))]) + stream = Stream([(Stream.PI, ('python', 'x = 2'), (None, -1, -1))]) output = stream.render(XMLSerializer) self.assertEqual('', output) def test_nested_default_namespaces(self): - xml = XML("""
-

-

""") - output = xml.render(XMLSerializer) - self.assertEqual("""
+ stream = Stream([ + (Stream.START_NS, ('', 'http://example.org/'), (None, -1, -1)), + (Stream.START, (QName('div'), Attrs()), (None, -1, -1)), + (Stream.TEXT, '\n ', (None, -1, -1)), + (Stream.START_NS, ('', 'http://example.org/'), (None, -1, -1)), + (Stream.START, (QName('p'), Attrs()), (None, -1, -1)), + (Stream.END, QName('p'), (None, -1, -1)), + (Stream.END_NS, '', (None, -1, -1)), + (Stream.TEXT, '\n ', (None, -1, -1)), + (Stream.START_NS, ('', 'http://example.org/'), (None, -1, -1)), + (Stream.START, (QName('p'), Attrs()), (None, -1, -1)), + (Stream.END, QName('p'), (None, -1, -1)), + (Stream.END_NS, '', (None, -1, -1)), + (Stream.TEXT, '\n ', (None, -1, -1)), + (Stream.END, QName('div'), (None, -1, -1)), + (Stream.END_NS, '', (None, -1, -1)) + ]) + output = stream.render(XMLSerializer) + self.assertEqual("""
+

""", output) def test_nested_bound_namespaces(self): - xml = XML("""
-

-

""") - output = xml.render(XMLSerializer) + stream = Stream([ + (Stream.START_NS, ('x', 'http://example.org/'), (None, -1, -1)), + (Stream.START, (QName('div'), Attrs()), (None, -1, -1)), + (Stream.TEXT, '\n ', (None, -1, -1)), + (Stream.START_NS, ('x', 'http://example.org/'), (None, -1, -1)), + (Stream.START, (QName('p'), Attrs()), (None, -1, -1)), + (Stream.END, QName('p'), (None, -1, -1)), + (Stream.END_NS, 'x', (None, -1, -1)), + (Stream.TEXT, '\n ', (None, -1, -1)), + (Stream.START_NS, ('x', 'http://example.org/'), (None, -1, -1)), + (Stream.START, (QName('p'), Attrs()), (None, -1, -1)), + (Stream.END, QName('p'), (None, -1, -1)), + (Stream.END_NS, 'x', (None, -1, -1)), + (Stream.TEXT, '\n ', (None, -1, -1)), + (Stream.END, QName('div'), (None, -1, -1)), + (Stream.END_NS, 'x', (None, -1, -1)) + ]) + output = stream.render(XMLSerializer) self.assertEqual("""

+

""", output) @@ -170,21 +204,51 @@ self.assertEqual(text, output) def test_nested_default_namespaces(self): - xml = XML("""
-

-

""") - output = xml.render(XHTMLSerializer) - self.assertEqual("""
+ stream = Stream([ + (Stream.START_NS, ('', 'http://example.org/'), (None, -1, -1)), + (Stream.START, (QName('div'), Attrs()), (None, -1, -1)), + (Stream.TEXT, '\n ', (None, -1, -1)), + (Stream.START_NS, ('', 'http://example.org/'), (None, -1, -1)), + (Stream.START, (QName('p'), Attrs()), (None, -1, -1)), + (Stream.END, QName('p'), (None, -1, -1)), + (Stream.END_NS, '', (None, -1, -1)), + (Stream.TEXT, '\n ', (None, -1, -1)), + (Stream.START_NS, ('', 'http://example.org/'), (None, -1, -1)), + (Stream.START, (QName('p'), Attrs()), (None, -1, -1)), + (Stream.END, QName('p'), (None, -1, -1)), + (Stream.END_NS, '', (None, -1, -1)), + (Stream.TEXT, '\n ', (None, -1, -1)), + (Stream.END, QName('div'), (None, -1, -1)), + (Stream.END_NS, '', (None, -1, -1)) + ]) + output = stream.render(XHTMLSerializer) + self.assertEqual("""
+

""", output) def test_nested_bound_namespaces(self): - xml = XML("""
- -
""") - output = xml.render(XHTMLSerializer) + stream = Stream([ + (Stream.START_NS, ('x', 'http://example.org/'), (None, -1, -1)), + (Stream.START, (QName('div'), Attrs()), (None, -1, -1)), + (Stream.TEXT, '\n ', (None, -1, -1)), + (Stream.START_NS, ('x', 'http://example.org/'), (None, -1, -1)), + (Stream.START, (QName('p'), Attrs()), (None, -1, -1)), + (Stream.END, QName('p'), (None, -1, -1)), + (Stream.END_NS, 'x', (None, -1, -1)), + (Stream.TEXT, '\n ', (None, -1, -1)), + (Stream.START_NS, ('x', 'http://example.org/'), (None, -1, -1)), + (Stream.START, (QName('p'), Attrs()), (None, -1, -1)), + (Stream.END, QName('p'), (None, -1, -1)), + (Stream.END_NS, 'x', (None, -1, -1)), + (Stream.TEXT, '\n ', (None, -1, -1)), + (Stream.END, QName('div'), (None, -1, -1)), + (Stream.END_NS, 'x', (None, -1, -1)) + ]) + output = stream.render(XHTMLSerializer) self.assertEqual("""
- +

+

""", output)