changeset: 98203:409bab2181d3 parent: 98200:1438ac605924 parent: 98202:9c248233754c user: Martin Panter date: Wed Sep 23 01:49:24 2015 +0000 files: Misc/NEWS description: Issue #25047: Merge Element Tree encoding from 3.5 diff -r 1438ac605924 -r 409bab2181d3 Lib/test/test_xml_etree.py --- a/Lib/test/test_xml_etree.py Tue Sep 22 18:21:13 2015 -0700 +++ b/Lib/test/test_xml_etree.py Wed Sep 23 01:49:24 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 1438ac605924 -r 409bab2181d3 Lib/xml/etree/ElementTree.py --- a/Lib/xml/etree/ElementTree.py Tue Sep 22 18:21:13 2015 -0700 +++ b/Lib/xml/etree/ElementTree.py Wed Sep 23 01:49:24 2015 +0000 @@ -752,14 +752,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 1438ac605924 -r 409bab2181d3 Misc/NEWS --- a/Misc/NEWS Tue Sep 22 18:21:13 2015 -0700 +++ b/Misc/NEWS Wed Sep 23 01:49:24 2015 +0000 @@ -138,6 +138,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.