Issue #17582: xml.etree.ElementTree nows preserves whitespaces in attributes
(Patch by Duane Griffin. Reviewed and approved by Stefan Behnel.)
This commit is contained in:
parent
4b73676c3d
commit
076366c2a5
|
@ -405,6 +405,14 @@ class ElementTreeTest(unittest.TestCase):
|
|||
self.assertEqual(ET.tostring(elem),
|
||||
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=" " b=" " c="	 " d=" " />')
|
||||
|
||||
def test_makeelement(self):
|
||||
# Test makeelement handling.
|
||||
|
||||
|
|
|
@ -1083,8 +1083,19 @@ def _escape_attrib(text):
|
|||
text = text.replace(">", ">")
|
||||
if "\"" in text:
|
||||
text = text.replace("\"", """)
|
||||
# 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:
|
||||
text = text.replace("\n", " ")
|
||||
if "\t" in text:
|
||||
text = text.replace("\t", "	")
|
||||
return text
|
||||
except (TypeError, AttributeError):
|
||||
_raise_serialization_error(text)
|
||||
|
|
|
@ -83,6 +83,9 @@ Library
|
|||
|
||||
- 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
|
||||
in the new email policies.
|
||||
|
||||
|
|
Loading…
Reference in New Issue