diff options
author | Nick Coghlan <ncoghlan@gmail.com> | 2017-02-09 16:08:17 +0100 |
---|---|---|
committer | Nick Coghlan <ncoghlan@gmail.com> | 2017-02-09 16:08:17 +0100 |
commit | c6180bb73c8c7c7f9d8ea9816487b710597b6fc1 (patch) | |
tree | fb4a5c18886537b4b7df46ed3b2aa579747ff507 /Lib/test/test_unicode_identifiers.py | |
parent | 5e0114a832a903518c4af6983161c0c2a8942a24 (diff) | |
parent | 819a21a3a4aac38f32e1ba4f68bcef45591fa3f0 (diff) | |
download | cpython-c6180bb73c8c7c7f9d8ea9816487b710597b6fc1.tar.gz |
Merge issue #26355 fix from Python 3.5
Diffstat (limited to 'Lib/test/test_unicode_identifiers.py')
-rw-r--r-- | Lib/test/test_unicode_identifiers.py | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/Lib/test/test_unicode_identifiers.py b/Lib/test/test_unicode_identifiers.py new file mode 100644 index 0000000000..0679845238 --- /dev/null +++ b/Lib/test/test_unicode_identifiers.py @@ -0,0 +1,31 @@ +import unittest +import sys + +class PEP3131Test(unittest.TestCase): + + def test_valid(self): + class T: + รค = 1 + ยต = 2 # this is a compatibility character + ่ = 3 + x๓ = 4 + self.assertEqual(getattr(T, "\xe4"), 1) + self.assertEqual(getattr(T, "\u03bc"), 2) + self.assertEqual(getattr(T, '\u87d2'), 3) + self.assertEqual(getattr(T, 'x\U000E0100'), 4) + + def test_non_bmp_normalized(self): + ๐๐ซ๐ฆ๐ ๐ฌ๐ก๐ข = 1 + self.assertIn("Unicode", dir()) + + def test_invalid(self): + try: + from test import badsyntax_3131 + except SyntaxError as s: + self.assertEqual(str(s), + "invalid character in identifier (badsyntax_3131.py, line 2)") + else: + self.fail("expected exception didn't occur") + +if __name__ == "__main__": + unittest.main() |