summaryrefslogtreecommitdiffstats
path: root/Lib
diff options
context:
space:
mode:
Diffstat (limited to 'Lib')
-rw-r--r--Lib/test/test_unicode.py39
1 files changed, 39 insertions, 0 deletions
diff --git a/Lib/test/test_unicode.py b/Lib/test/test_unicode.py
index f6c38dd..2ac79fb 100644
--- a/Lib/test/test_unicode.py
+++ b/Lib/test/test_unicode.py
@@ -1394,6 +1394,45 @@ class UnicodeTest(string_tests.CommonTest,
'string, got a non-ASCII byte: 0xe9$',
format_unicode, b'unicode\xe9=%s', 'ascii')
+ # Test PyUnicode_AsWideChar()
+ def test_aswidechar(self):
+ from _testcapi import test_aswidechar
+ from ctypes import c_wchar, sizeof
+
+ wchar, size = test_aswidechar('abcdef', 2)
+ self.assertEquals(size, 2)
+ self.assertEquals(wchar, 'ab')
+
+ wchar, size = test_aswidechar('abc', 3)
+ self.assertEquals(size, 3)
+ self.assertEquals(wchar, 'abc')
+
+ wchar, size = test_aswidechar('abc', 4)
+ self.assertEquals(size, 3)
+ self.assertEquals(wchar, 'abc\0')
+
+ wchar, size = test_aswidechar('abc', 10)
+ self.assertEquals(size, 3)
+ self.assertEquals(wchar, 'abc\0')
+
+ wchar, size = test_aswidechar('abc\0def', 20)
+ self.assertEquals(size, 7)
+ self.assertEquals(wchar, 'abc\0def\0')
+
+ # Test PyUnicode_AsWideCharString()
+ def test_aswidecharstring(self):
+ from _testcapi import test_aswidecharstring
+ from ctypes import c_wchar, sizeof
+
+ wchar, size = test_aswidecharstring('abc')
+ self.assertEquals(size, 3)
+ self.assertEquals(wchar, 'abc\0')
+
+ wchar, size = test_aswidecharstring('abc\0def')
+ self.assertEquals(size, 7)
+ self.assertEquals(wchar, 'abc\0def\0')
+
+
def test_main():
support.run_unittest(__name__)