示例#1
0
if sys.version_info[0:2] >= (3, 1):
    test_string = "h\udce9llo w\u00f6rld"
    if unicode_strings.non_utf8_c_str() != test_string:
        raise ValueError("Test comparison mismatch")
    if unicode_strings.non_utf8_std_string() != test_string:
        raise ValueError("Test comparison mismatch")


def check(s1, s2):
    if s1 != s2:
        raise RuntimeError("{} != {}".format(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):
    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("hello4")), "hello4")
    unicode_strings.charstring(u"hell\xb05")
    unicode_strings.charstring(u"hell\u00f66")
    low_surrogate_string = u"\udcff"
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:
示例#2
0
# mark this as a unicode string in 2.x so it'll become a str in 3.x.
test_string = u'h\udce9llo w\u00f6rld'

if sys.version_info[0:2] >= (3, 1):
    if unicode_strings.non_utf8_c_str() != test_string:
        raise ValueError('Test comparison mismatch')
    if unicode_strings.non_utf8_std_string() != test_string:
        raise ValueError('Test comparison mismatch')

def check(s1, s2):
    if s1 != s2:
        raise RuntimeError("{} != {}".format(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):
    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(unicode("hello4")), "hello4")
    unicode_strings.charstring(u"hell\xb05")
    unicode_strings.charstring(u"hell\u00f66")

low_surrogate_string = u"\udcff"
try:
    unicode_strings.instring(low_surrogate_string)
    # Will succeed with Python 2
except TypeError, 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
import sys

import unicode_strings

# The 'u' string prefix isn't valid in Python 3.0 - 3.2 and is redundant
# in 3.3+. Since this file is run through 2to3 before testing, though,
# mark this as a unicode string in 2.x so it'll become a str in 3.x.
test_string = u'h\udce9llo w\u00f6rld'

if sys.version_info[0:2] >= (3, 1):
    if unicode_strings.non_utf8_c_str() != test_string:
        raise ValueError('Test comparison mismatch')
    if unicode_strings.non_utf8_std_string() != test_string:
        raise ValueError('Test comparison mismatch')

# Testing SWIG_PYTHON_2_UNICODE flag which allows unicode strings to be passed to C
if sys.version_info[0:2] < (3, 0):
    assert unicode_strings.charstring("hello1") == "hello1"
    assert unicode_strings.charstring(str(u"hello2")) == "hello2"
    assert unicode_strings.charstring(u"hello3") == "hello3"
    assert unicode_strings.charstring(unicode("hello4")) == "hello4"
    unicode_strings.charstring(u"hell\xb05")
    unicode_strings.charstring(u"hell\u00f66")
示例#4
0
    test_string = "h\udce9llo w\u00f6rld"
    if unicode_strings.non_utf8_c_str() != test_string:
        raise ValueError("Test comparison mismatch")
    if unicode_strings.non_utf8_std_string() != test_string:
        raise ValueError("Test comparison mismatch")

def check(s1, s2):
    if s1 != s2:
        raise RuntimeError("{} != {}".format(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(unicode("hello2"))), "hello2") # u"hello2"
    check(unicode_strings.charstring(unicode("hello3")), "hello3") # u"hello3"
    check(unicode_strings.charstring(str("hello4")), "hello4")
    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)
        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: