summaryrefslogtreecommitdiff
path: root/Lib/test/test_unicode_identifiers.py
diff options
context:
space:
mode:
authorNick Coghlan <ncoghlan@gmail.com>2017-02-09 16:08:17 +0100
committerNick Coghlan <ncoghlan@gmail.com>2017-02-09 16:08:17 +0100
commitc6180bb73c8c7c7f9d8ea9816487b710597b6fc1 (patch)
treefb4a5c18886537b4b7df46ed3b2aa579747ff507 /Lib/test/test_unicode_identifiers.py
parent5e0114a832a903518c4af6983161c0c2a8942a24 (diff)
parent819a21a3a4aac38f32e1ba4f68bcef45591fa3f0 (diff)
downloadcpython-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.py31
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()