diff --git a/repoze/xmliter/serializer.py b/repoze/xmliter/serializer.py index b7d909e..6ff5d5f 100644 --- a/repoze/xmliter/serializer.py +++ b/repoze/xmliter/serializer.py @@ -7,7 +7,7 @@ doctype_re_u = re.compile(u"^]+>\\s*", re.MULTILINE) class XMLSerializer(object): - + def __init__(self, tree, serializer=None, pretty_print=False, doctype=None): if serializer is None: serializer = lxml.etree.tostring @@ -21,7 +21,10 @@ def __init__(self, tree, serializer=None, pretty_print=False, doctype=None): def serialize(self, encoding=None): # Defer to the xsl:output settings if appropriate if isinstance(self.tree, lxml.etree._XSLTResultTree): - result = str(self.tree) + if encoding is str: + result = str(self.tree) + else: + result = bytes(self.tree) else: result = self.serializer(self.tree, encoding=encoding, pretty_print=self.pretty_print) if self.doctype is not None: @@ -36,7 +39,7 @@ def __iter__(self): def __str__(self): return self.serialize(str) - + def __bytes__(self): return self.serialize() diff --git a/repoze/xmliter/tests.py b/repoze/xmliter/tests.py index ea17e91..1226885 100644 --- a/repoze/xmliter/tests.py +++ b/repoze/xmliter/tests.py @@ -8,9 +8,6 @@ import lxml.html import lxml.etree -import sys -if sys.version_info > (3,): - unicode = str class TestIterator(unittest.TestCase): @@ -34,7 +31,7 @@ def test_html_serialization(self): """Test HTML serialization.""" @decorator.lazy(serializer=lxml.html.tostring) - def app(a, b, c=u""): + def app(a, b, c=""): tree = self.create_tree() tree.find('body').attrib['class'] = " ".join((a, b, c)) return tree @@ -48,13 +45,13 @@ def app(a, b, c=u""): # With Unicode encoding: self.assertEqual( lxml.html.tostring(result.tree, encoding='unicode'), - u"".join(result.serialize(encoding=unicode))) + "".join(result.serialize(encoding=str))) def test_xml_serialization(self): """Test XML serialization.""" @decorator.lazy - def app(a, b, c=u""): + def app(a, b, c=""): tree = self.create_tree() tree.find('body').attrib['class'] = " ".join((a, b, c)) return tree @@ -68,7 +65,7 @@ def app(a, b, c=u""): # With Unicode encoding: self.assertEqual( lxml.etree.tostring(result.tree, encoding='unicode'), - u"".join(result.serialize(encoding=unicode))) + "".join(result.serialize(encoding=str))) def test_decorator_instancemethod(self): class test(object): @@ -86,7 +83,7 @@ def __call__(self, tree): self.assertEqual( lxml.etree.tostring(result.tree, encoding='unicode'), - u"".join(result.serialize(encoding=unicode))) + "".join(result.serialize(encoding=str))) def test_getXMLSerializer(self): t = utils.getXMLSerializer(self.create_iterable()) @@ -100,8 +97,8 @@ def test_getXMLSerializer(self): b"".join(t2)) self.assertEqual( - u"