summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorWilliam S Fulton <wsf@fultondesigns.co.uk>2020-08-15 23:51:40 +0100
committerWilliam S Fulton <wsf@fultondesigns.co.uk>2020-08-15 23:51:40 +0100
commitb1c0145fd3d5e899552e8e4f83194f2dd365eb42 (patch)
treea3144e1372167704ab6253f6e6cd386d4930a82a
parentc5e078c4374dc019966fd023d6ec296ac478d169 (diff)
downloadswig-b1c0145fd3d5e899552e8e4f83194f2dd365eb42.tar.gz
Python 3.2 syntax error fixes in tests
-rw-r--r--Examples/test-suite/python/python_strict_unicode_runme.py11
-rw-r--r--Examples/test-suite/python/unicode_strings_runme.py31
2 files changed, 24 insertions, 18 deletions
diff --git a/Examples/test-suite/python/python_strict_unicode_runme.py b/Examples/test-suite/python/python_strict_unicode_runme.py
index ba0e7d965..79c768de1 100644
--- a/Examples/test-suite/python/python_strict_unicode_runme.py
+++ b/Examples/test-suite/python/python_strict_unicode_runme.py
@@ -5,13 +5,16 @@ test_bytes = b"hello \x01world\x99"
BYTES = b"BYTES"
if sys.version_info[0:2] < (3, 0):
- test_unicode = u"h\udce9llo w\u00f6rld"
- UNICODE = u"UNICODE"
- type_unicode_string = type(u"")
+ # Python 3.0-3.2 results in a SyntaxError when using u"" string literals, so we use a
+ # convoluted unicode string construction using unicode() and unichr().
+ # Conventional Python 2 syntax shown in comments.
+ test_unicode = unicode("h" + unichr(0xdce9) + "llo w" + unichr(0x00f6) + "rld") # u"h\udce9llo w\u00f6rld"
+ UNICODE = unicode("UNICODE")
+ type_unicode_string = type(UNICODE)
else:
test_unicode = "h\udce9llo w\u00f6rld"
UNICODE = "UNICODE"
- type_unicode_string = type("")
+ type_unicode_string = type(UNICODE)
# Test that byte string inputs and outputs work as expected
bdbl = python_strict_unicode.double_str(test_bytes)
diff --git a/Examples/test-suite/python/unicode_strings_runme.py b/Examples/test-suite/python/unicode_strings_runme.py
index 108d0d2c9..57bd7abca 100644
--- a/Examples/test-suite/python/unicode_strings_runme.py
+++ b/Examples/test-suite/python/unicode_strings_runme.py
@@ -15,21 +15,24 @@ def check(s1, s2):
# Testing SWIG_PYTHON_2_UNICODE flag which allows unicode strings to be passed to C
if sys.version_info[0:2] < (3, 0):
+ # Python 3.0-3.2 results in a SyntaxError when using u"" string literals, so we use a
+ # convoluted unicode string construction using unicode() and unichr().
+ # Conventional Python 2 syntax shown in comments.
check(unicode_strings.charstring("hello1"), "hello1")
- check(unicode_strings.charstring(str(u"hello2")), "hello2")
- check(unicode_strings.charstring(u"hello3"), "hello3")
+ check(unicode_strings.charstring(str(unicode("hello2"))), "hello2") # u"hello2"
+ check(unicode_strings.charstring(unicode("hello3")), "hello3") # u"hello3"
check(unicode_strings.charstring(str("hello4")), "hello4")
- unicode_strings.charstring(u"hell\xb05")
- unicode_strings.charstring(u"hell\u00f66")
- low_surrogate_string = u"\udcff"
+ unicode_strings.charstring(unicode("hell" + unichr(0xb0) + "5")) # u"hell\xb05"
+ unicode_strings.charstring(unicode("hell" + unichr(0x00f6) +"6")) # u"hell\u00f66"
+ low_surrogate_string = unichr(0xdcff) # u"\udcff"
+ unicode_strings.instring(low_surrogate_string)
else:
low_surrogate_string = "\udcff"
-
-try:
- unicode_strings.instring(low_surrogate_string)
- # Will succeed with Python 2
-except TypeError as e:
- # Python 3 will fail the PyUnicode_AsUTF8String conversion resulting in a TypeError.
- # The real error is actually:
- # UnicodeEncodeError: 'utf-8' codec can't encode character '\udcff' in position 0: surrogates not allowed
- pass
+ try:
+ unicode_strings.instring(low_surrogate_string)
+ raise RuntimeError("Exception should have been thrown")
+ except TypeError as e:
+ # Python 3 will fail the PyUnicode_AsUTF8String conversion resulting in a TypeError.
+ # The real error is actually:
+ # UnicodeEncodeError: 'utf-8' codec can't encode character '\udcff' in position 0: surrogates not allowed
+ pass