This commit is contained in:
Raymond Hettinger 2016-09-11 23:23:24 -07:00
commit 11fa3ffcb1
3 changed files with 22 additions and 0 deletions

View File

@ -409,6 +409,14 @@ class ElementTreeTest(unittest.TestCase):
self.assertEqual(ET.tostring(elem), self.assertEqual(ET.tostring(elem),
b'<test testa="testval" testb="test1" testc="test2">aa</test>') b'<test testa="testval" testb="test1" testc="test2">aa</test>')
elem = ET.Element('test')
elem.set('a', '\r')
elem.set('b', '\r\n')
elem.set('c', '\t\n\r ')
elem.set('d', '\n\n')
self.assertEqual(ET.tostring(elem),
b'<test a="&#10;" b="&#10;" c="&#09;&#10;&#10; " d="&#10;&#10;" />')
def test_makeelement(self): def test_makeelement(self):
# Test makeelement handling. # Test makeelement handling.

View File

@ -1084,8 +1084,19 @@ def _escape_attrib(text):
text = text.replace(">", "&gt;") text = text.replace(">", "&gt;")
if "\"" in text: if "\"" in text:
text = text.replace("\"", "&quot;") text = text.replace("\"", "&quot;")
# The following business with carriage returns is to satisfy
# Section 2.11 of the XML specification, stating that
# CR or CR LN should be replaced with just LN
# http://www.w3.org/TR/REC-xml/#sec-line-ends
if "\r\n" in text:
text = text.replace("\r\n", "\n")
if "\r" in text:
text = text.replace("\r", "\n")
#The following four lines are issue 17582
if "\n" in text: if "\n" in text:
text = text.replace("\n", "&#10;") text = text.replace("\n", "&#10;")
if "\t" in text:
text = text.replace("\t", "&#09;")
return text return text
except (TypeError, AttributeError): except (TypeError, AttributeError):
_raise_serialization_error(text) _raise_serialization_error(text)

View File

@ -209,6 +209,9 @@ Library
- Issue #24594: Validates persist parameter when opening MSI database - Issue #24594: Validates persist parameter when opening MSI database
- Issue #17582: xml.etree.ElementTree nows preserves whitespaces in attributes
(Patch by Duane Griffin. Reviewed and approved by Stefan Behnel.)
- Issue #28047: Fixed calculation of line length used for the base64 CTE - Issue #28047: Fixed calculation of line length used for the base64 CTE
in the new email policies. in the new email policies.