changeset: 98201:ff7aba08ada6 branch: 3.4 parent: 98196:86dcaadc7957 user: Martin Panter date: Wed Sep 23 01:14:35 2015 +0000 files: Lib/test/test_xml_etree.py Lib/xml/etree/ElementTree.py Misc/NEWS description: Issue #25047: Respect case writing XML encoding declarations This restores the ability to write encoding names in uppercase like "UTF-8", which worked in Python 2. diff -r 86dcaadc7957 -r ff7aba08ada6 Lib/test/test_xml_etree.py --- a/Lib/test/test_xml_etree.py Tue Sep 22 21:13:28 2015 -0400 +++ b/Lib/test/test_xml_etree.py Wed Sep 23 01:14:35 2015 +0000 @@ -2396,14 +2396,21 @@ elem = ET.Element("tag") elem.text = "abc" self.assertEqual(serialize(elem), 'abc') - self.assertEqual(serialize(elem, encoding="utf-8"), - b'abc') - self.assertEqual(serialize(elem, encoding="us-ascii"), - b'abc') + for enc in ("utf-8", "us-ascii"): + with self.subTest(enc): + self.assertEqual(serialize(elem, encoding=enc), + b'abc') + self.assertEqual(serialize(elem, encoding=enc.upper()), + b'abc') for enc in ("iso-8859-1", "utf-16", "utf-32"): - self.assertEqual(serialize(elem, encoding=enc), - ("\n" - "abc" % enc).encode(enc)) + with self.subTest(enc): + self.assertEqual(serialize(elem, encoding=enc), + ("\n" + "abc" % enc).encode(enc)) + upper = enc.upper() + self.assertEqual(serialize(elem, encoding=upper), + ("\n" + "abc" % upper).encode(enc)) elem = ET.Element("tag") elem.text = "<&\"\'>" diff -r 86dcaadc7957 -r ff7aba08ada6 Lib/xml/etree/ElementTree.py --- a/Lib/xml/etree/ElementTree.py Tue Sep 22 21:13:28 2015 -0400 +++ b/Lib/xml/etree/ElementTree.py Wed Sep 23 01:14:35 2015 +0000 @@ -756,14 +756,13 @@ encoding = "utf-8" else: encoding = "us-ascii" - else: - encoding = encoding.lower() - with _get_writer(file_or_filename, encoding) as write: + enc_lower = encoding.lower() + with _get_writer(file_or_filename, enc_lower) as write: if method == "xml" and (xml_declaration or (xml_declaration is None and - encoding not in ("utf-8", "us-ascii", "unicode"))): + enc_lower not in ("utf-8", "us-ascii", "unicode"))): declared_encoding = encoding - if encoding == "unicode": + if enc_lower == "unicode": # Retrieve the default encoding for the xml declaration import locale declared_encoding = locale.getpreferredencoding() diff -r 86dcaadc7957 -r ff7aba08ada6 Misc/NEWS --- a/Misc/NEWS Tue Sep 22 21:13:28 2015 -0400 +++ b/Misc/NEWS Wed Sep 23 01:14:35 2015 +0000 @@ -81,6 +81,10 @@ Library ------- +- Issue #25047: The XML encoding declaration written by Element Tree now + respects the letter case given by the user. This restores the ability to + write encoding names in uppercase like "UTF-8", which worked in Python 2. + - Issue #19143: platform module now reads Windows version from kernel32.dll to avoid compatibility shims.