| Guido van Rossum | a831cac | 2000-03-10 23:23:21 +0000 | [diff] [blame] | 1 | """ Test script for the Unicode implementation. | 
|  | 2 |  | 
| Guido van Rossum | a831cac | 2000-03-10 23:23:21 +0000 | [diff] [blame] | 3 | Written by Marc-Andre Lemburg (mal@lemburg.com). | 
|  | 4 |  | 
|  | 5 | (c) Copyright CNRI, All Rights Reserved. NO WARRANTY. | 
|  | 6 |  | 
|  | 7 | """ | 
|  | 8 | from test_support import verbose | 
|  | 9 | import sys | 
|  | 10 |  | 
|  | 11 | def test(method, input, output, *args): | 
|  | 12 | if verbose: | 
|  | 13 | print '%s.%s%s =? %s... ' % (repr(input), method, args, output), | 
|  | 14 | try: | 
|  | 15 | f = getattr(input, method) | 
|  | 16 | value = apply(f, args) | 
|  | 17 | except: | 
|  | 18 | value = sys.exc_type | 
| Guido van Rossum | 6650320 | 2000-04-28 20:39:58 +0000 | [diff] [blame] | 19 | exc = sys.exc_info()[:2] | 
| Guido van Rossum | a831cac | 2000-03-10 23:23:21 +0000 | [diff] [blame] | 20 | else: | 
|  | 21 | exc = None | 
|  | 22 | if value != output: | 
|  | 23 | if verbose: | 
|  | 24 | print 'no' | 
|  | 25 | print '*',f, `input`, `output`, `value` | 
|  | 26 | if exc: | 
| Guido van Rossum | 6650320 | 2000-04-28 20:39:58 +0000 | [diff] [blame] | 27 | print '  value == %s: %s' % (exc) | 
| Guido van Rossum | a831cac | 2000-03-10 23:23:21 +0000 | [diff] [blame] | 28 | else: | 
|  | 29 | if verbose: | 
|  | 30 | print 'yes' | 
|  | 31 |  | 
|  | 32 | test('capitalize', u' hello ', u' hello ') | 
|  | 33 | test('capitalize', u'hello ', u'Hello ') | 
|  | 34 |  | 
|  | 35 | test('title', u' hello ', u' Hello ') | 
|  | 36 | test('title', u'hello ', u'Hello ') | 
|  | 37 | test('title', u"fOrMaT thIs aS titLe String", u'Format This As Title String') | 
|  | 38 | test('title', u"fOrMaT,thIs-aS*titLe;String", u'Format,This-As*Title;String') | 
|  | 39 | test('title', u"getInt", u'Getint') | 
|  | 40 |  | 
|  | 41 | test('find', u'abcdefghiabc', 0, u'abc') | 
|  | 42 | test('find', u'abcdefghiabc', 9, u'abc', 1) | 
|  | 43 | test('find', u'abcdefghiabc', -1, u'def', 4) | 
|  | 44 |  | 
|  | 45 | test('rfind', u'abcdefghiabc', 9, u'abc') | 
|  | 46 |  | 
|  | 47 | test('lower', u'HeLLo', u'hello') | 
|  | 48 | test('lower', u'hello', u'hello') | 
|  | 49 |  | 
|  | 50 | test('upper', u'HeLLo', u'HELLO') | 
|  | 51 | test('upper', u'HELLO', u'HELLO') | 
|  | 52 |  | 
|  | 53 | if 0: | 
|  | 54 | transtable = '\000\001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037 !"#$%&\'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`xyzdefghijklmnopqrstuvwxyz{|}~\177\200\201\202\203\204\205\206\207\210\211\212\213\214\215\216\217\220\221\222\223\224\225\226\227\230\231\232\233\234\235\236\237\240\241\242\243\244\245\246\247\250\251\252\253\254\255\256\257\260\261\262\263\264\265\266\267\270\271\272\273\274\275\276\277\300\301\302\303\304\305\306\307\310\311\312\313\314\315\316\317\320\321\322\323\324\325\326\327\330\331\332\333\334\335\336\337\340\341\342\343\344\345\346\347\350\351\352\353\354\355\356\357\360\361\362\363\364\365\366\367\370\371\372\373\374\375\376\377' | 
|  | 55 |  | 
|  | 56 | test('maketrans', u'abc', transtable, u'xyz') | 
|  | 57 | test('maketrans', u'abc', ValueError, u'xyzq') | 
|  | 58 |  | 
|  | 59 | test('split', u'this is the split function', | 
|  | 60 | [u'this', u'is', u'the', u'split', u'function']) | 
|  | 61 | test('split', u'a|b|c|d', [u'a', u'b', u'c', u'd'], u'|') | 
|  | 62 | test('split', u'a|b|c|d', [u'a', u'b', u'c|d'], u'|', 2) | 
|  | 63 | test('split', u'a b c d', [u'a', u'b c d'], None, 1) | 
|  | 64 | test('split', u'a b c d', [u'a', u'b', u'c d'], None, 2) | 
|  | 65 | test('split', u'a b c d', [u'a', u'b', u'c', u'd'], None, 3) | 
|  | 66 | test('split', u'a b c d', [u'a', u'b', u'c', u'd'], None, 4) | 
|  | 67 | test('split', u'a b c d', [u'a b c d'], None, 0) | 
|  | 68 | test('split', u'a  b  c  d', [u'a', u'b', u'c  d'], None, 2) | 
|  | 69 | test('split', u'a b c d ', [u'a', u'b', u'c', u'd']) | 
|  | 70 |  | 
|  | 71 | # join now works with any sequence type | 
|  | 72 | class Sequence: | 
|  | 73 | def __init__(self): self.seq = 'wxyz' | 
|  | 74 | def __len__(self): return len(self.seq) | 
|  | 75 | def __getitem__(self, i): return self.seq[i] | 
|  | 76 |  | 
|  | 77 | test('join', u' ', u'a b c d', [u'a', u'b', u'c', u'd']) | 
|  | 78 | test('join', u'', u'abcd', (u'a', u'b', u'c', u'd')) | 
|  | 79 | test('join', u' ', u'w x y z', Sequence()) | 
|  | 80 | test('join', u' ', TypeError, 7) | 
|  | 81 |  | 
|  | 82 | class BadSeq(Sequence): | 
|  | 83 | def __init__(self): self.seq = [7, u'hello', 123L] | 
|  | 84 |  | 
|  | 85 | test('join', u' ', TypeError, BadSeq()) | 
|  | 86 |  | 
|  | 87 | result = u'' | 
|  | 88 | for i in range(10): | 
|  | 89 | if i > 0: | 
|  | 90 | result = result + u':' | 
|  | 91 | result = result + u'x'*10 | 
|  | 92 | test('join', u':', result, [u'x' * 10] * 10) | 
|  | 93 | test('join', u':', result, (u'x' * 10,) * 10) | 
|  | 94 |  | 
|  | 95 | test('strip', u'   hello   ', u'hello') | 
|  | 96 | test('lstrip', u'   hello   ', u'hello   ') | 
|  | 97 | test('rstrip', u'   hello   ', u'   hello') | 
|  | 98 | test('strip', u'hello', u'hello') | 
|  | 99 |  | 
|  | 100 | test('swapcase', u'HeLLo cOmpUteRs', u'hEllO CoMPuTErS') | 
|  | 101 |  | 
|  | 102 | if 0: | 
|  | 103 | test('translate', u'xyzabcdef', u'xyzxyz', transtable, u'def') | 
|  | 104 |  | 
|  | 105 | table = string.maketrans('a', u'A') | 
|  | 106 | test('translate', u'abc', u'Abc', table) | 
|  | 107 | test('translate', u'xyz', u'xyz', table) | 
|  | 108 |  | 
|  | 109 | test('replace', u'one!two!three!', u'one@two!three!', u'!', u'@', 1) | 
| Barry Warsaw | 51ac580 | 2000-03-20 16:36:48 +0000 | [diff] [blame] | 110 | test('replace', u'one!two!three!', u'onetwothree', '!', '') | 
| Guido van Rossum | a831cac | 2000-03-10 23:23:21 +0000 | [diff] [blame] | 111 | test('replace', u'one!two!three!', u'one@two@three!', u'!', u'@', 2) | 
|  | 112 | test('replace', u'one!two!three!', u'one@two@three@', u'!', u'@', 3) | 
|  | 113 | test('replace', u'one!two!three!', u'one@two@three@', u'!', u'@', 4) | 
|  | 114 | test('replace', u'one!two!three!', u'one!two!three!', u'!', u'@', 0) | 
|  | 115 | test('replace', u'one!two!three!', u'one@two@three@', u'!', u'@') | 
|  | 116 | test('replace', u'one!two!three!', u'one!two!three!', u'x', u'@') | 
|  | 117 | test('replace', u'one!two!three!', u'one!two!three!', u'x', u'@', 2) | 
|  | 118 |  | 
|  | 119 | test('startswith', u'hello', 1, u'he') | 
|  | 120 | test('startswith', u'hello', 1, u'hello') | 
|  | 121 | test('startswith', u'hello', 0, u'hello world') | 
|  | 122 | test('startswith', u'hello', 1, u'') | 
|  | 123 | test('startswith', u'hello', 0, u'ello') | 
|  | 124 | test('startswith', u'hello', 1, u'ello', 1) | 
|  | 125 | test('startswith', u'hello', 1, u'o', 4) | 
|  | 126 | test('startswith', u'hello', 0, u'o', 5) | 
|  | 127 | test('startswith', u'hello', 1, u'', 5) | 
|  | 128 | test('startswith', u'hello', 0, u'lo', 6) | 
|  | 129 | test('startswith', u'helloworld', 1, u'lowo', 3) | 
|  | 130 | test('startswith', u'helloworld', 1, u'lowo', 3, 7) | 
|  | 131 | test('startswith', u'helloworld', 0, u'lowo', 3, 6) | 
|  | 132 |  | 
|  | 133 | test('endswith', u'hello', 1, u'lo') | 
|  | 134 | test('endswith', u'hello', 0, u'he') | 
|  | 135 | test('endswith', u'hello', 1, u'') | 
|  | 136 | test('endswith', u'hello', 0, u'hello world') | 
|  | 137 | test('endswith', u'helloworld', 0, u'worl') | 
|  | 138 | test('endswith', u'helloworld', 1, u'worl', 3, 9) | 
|  | 139 | test('endswith', u'helloworld', 1, u'world', 3, 12) | 
|  | 140 | test('endswith', u'helloworld', 1, u'lowo', 1, 7) | 
|  | 141 | test('endswith', u'helloworld', 1, u'lowo', 2, 7) | 
|  | 142 | test('endswith', u'helloworld', 1, u'lowo', 3, 7) | 
|  | 143 | test('endswith', u'helloworld', 0, u'lowo', 4, 7) | 
|  | 144 | test('endswith', u'helloworld', 0, u'lowo', 3, 8) | 
|  | 145 | test('endswith', u'ab', 0, u'ab', 0, 1) | 
|  | 146 | test('endswith', u'ab', 0, u'ab', 0, 0) | 
|  | 147 |  | 
|  | 148 | test('expandtabs', u'abc\rab\tdef\ng\thi', u'abc\rab      def\ng       hi') | 
|  | 149 | test('expandtabs', u'abc\rab\tdef\ng\thi', u'abc\rab      def\ng       hi', 8) | 
|  | 150 | test('expandtabs', u'abc\rab\tdef\ng\thi', u'abc\rab  def\ng   hi', 4) | 
|  | 151 | test('expandtabs', u'abc\r\nab\tdef\ng\thi', u'abc\r\nab  def\ng   hi', 4) | 
|  | 152 |  | 
|  | 153 | if 0: | 
|  | 154 | test('capwords', u'abc def ghi', u'Abc Def Ghi') | 
|  | 155 | test('capwords', u'abc\tdef\nghi', u'Abc Def Ghi') | 
|  | 156 | test('capwords', u'abc\t   def  \nghi', u'Abc Def Ghi') | 
|  | 157 |  | 
|  | 158 | # Comparisons: | 
|  | 159 | print 'Testing Unicode comparisons...', | 
|  | 160 | assert u'abc' == 'abc' | 
|  | 161 | assert 'abc' == u'abc' | 
|  | 162 | assert u'abc' == u'abc' | 
|  | 163 | assert u'abcd' > 'abc' | 
|  | 164 | assert 'abcd' > u'abc' | 
|  | 165 | assert u'abcd' > u'abc' | 
|  | 166 | assert u'abc' < 'abcd' | 
|  | 167 | assert 'abc' < u'abcd' | 
|  | 168 | assert u'abc' < u'abcd' | 
|  | 169 | print 'done.' | 
|  | 170 |  | 
|  | 171 | test('ljust', u'abc',  u'abc       ', 10) | 
|  | 172 | test('rjust', u'abc',  u'       abc', 10) | 
|  | 173 | test('center', u'abc', u'   abc    ', 10) | 
|  | 174 | test('ljust', u'abc',  u'abc   ', 6) | 
|  | 175 | test('rjust', u'abc',  u'   abc', 6) | 
|  | 176 | test('center', u'abc', u' abc  ', 6) | 
|  | 177 | test('ljust', u'abc', u'abc', 2) | 
|  | 178 | test('rjust', u'abc', u'abc', 2) | 
|  | 179 | test('center', u'abc', u'abc', 2) | 
|  | 180 |  | 
|  | 181 | test('islower', u'a', 1) | 
|  | 182 | test('islower', u'A', 0) | 
|  | 183 | test('islower', u'\n', 0) | 
|  | 184 | test('islower', u'\u1FFc', 0) | 
|  | 185 | test('islower', u'abc', 1) | 
|  | 186 | test('islower', u'aBc', 0) | 
|  | 187 | test('islower', u'abc\n', 1) | 
|  | 188 |  | 
|  | 189 | test('isupper', u'a', 0) | 
|  | 190 | test('isupper', u'A', 1) | 
|  | 191 | test('isupper', u'\n', 0) | 
|  | 192 | test('isupper', u'\u1FFc', 0) | 
|  | 193 | test('isupper', u'ABC', 1) | 
|  | 194 | test('isupper', u'AbC', 0) | 
|  | 195 | test('isupper', u'ABC\n', 1) | 
|  | 196 |  | 
|  | 197 | test('istitle', u'a', 0) | 
|  | 198 | test('istitle', u'A', 1) | 
|  | 199 | test('istitle', u'\n', 0) | 
|  | 200 | test('istitle', u'\u1FFc', 1) | 
|  | 201 | test('istitle', u'A Titlecased Line', 1) | 
|  | 202 | test('istitle', u'A\nTitlecased Line', 1) | 
|  | 203 | test('istitle', u'A Titlecased, Line', 1) | 
|  | 204 | test('istitle', u'Greek \u1FFcitlecases ...', 1) | 
|  | 205 | test('istitle', u'Not a capitalized String', 0) | 
|  | 206 | test('istitle', u'Not\ta Titlecase String', 0) | 
|  | 207 | test('istitle', u'Not--a Titlecase String', 0) | 
|  | 208 |  | 
|  | 209 | test('splitlines', u"abc\ndef\n\rghi", [u'abc', u'def', u'', u'ghi']) | 
|  | 210 | test('splitlines', u"abc\ndef\n\r\nghi", [u'abc', u'def', u'', u'ghi']) | 
|  | 211 | test('splitlines', u"abc\ndef\r\nghi", [u'abc', u'def', u'ghi']) | 
|  | 212 | test('splitlines', u"abc\ndef\r\nghi\n", [u'abc', u'def', u'ghi']) | 
|  | 213 | test('splitlines', u"abc\ndef\r\nghi\n\r", [u'abc', u'def', u'ghi', u'']) | 
|  | 214 | test('splitlines', u"\nabc\ndef\r\nghi\n\r", [u'', u'abc', u'def', u'ghi', u'']) | 
| Guido van Rossum | 7ee801d | 2000-04-11 15:37:02 +0000 | [diff] [blame] | 215 | test('splitlines', u"\nabc\ndef\r\nghi\n\r", [u'\n', u'abc\n', u'def\r\n', u'ghi\n', u'\r'], 1) | 
| Guido van Rossum | a831cac | 2000-03-10 23:23:21 +0000 | [diff] [blame] | 216 |  | 
|  | 217 | test('translate', u"abababc", u'bbbc', {ord('a'):None}) | 
|  | 218 | test('translate', u"abababc", u'iiic', {ord('a'):None, ord('b'):ord('i')}) | 
|  | 219 | test('translate', u"abababc", u'iiix', {ord('a'):None, ord('b'):ord('i'), ord('c'):u'x'}) | 
|  | 220 |  | 
| Guido van Rossum | d4d2684 | 2000-03-13 23:21:48 +0000 | [diff] [blame] | 221 | # Contains: | 
|  | 222 | print 'Testing Unicode contains method...', | 
| Guido van Rossum | 9e896b3 | 2000-04-05 20:11:21 +0000 | [diff] [blame] | 223 | assert ('a' in u'abdb') == 1 | 
|  | 224 | assert ('a' in u'bdab') == 1 | 
|  | 225 | assert ('a' in u'bdaba') == 1 | 
|  | 226 | assert ('a' in u'bdba') == 1 | 
| Guido van Rossum | d4d2684 | 2000-03-13 23:21:48 +0000 | [diff] [blame] | 227 | assert ('a' in u'bdba') == 1 | 
|  | 228 | assert (u'a' in u'bdba') == 1 | 
|  | 229 | assert (u'a' in u'bdb') == 0 | 
|  | 230 | assert (u'a' in 'bdb') == 0 | 
|  | 231 | assert (u'a' in 'bdba') == 1 | 
| Guido van Rossum | 9e896b3 | 2000-04-05 20:11:21 +0000 | [diff] [blame] | 232 | assert (u'a' in ('a',1,None)) == 1 | 
|  | 233 | assert (u'a' in (1,None,'a')) == 1 | 
|  | 234 | assert (u'a' in (1,None,u'a')) == 1 | 
|  | 235 | assert ('a' in ('a',1,None)) == 1 | 
|  | 236 | assert ('a' in (1,None,'a')) == 1 | 
|  | 237 | assert ('a' in (1,None,u'a')) == 1 | 
|  | 238 | assert ('a' in ('x',1,u'y')) == 0 | 
|  | 239 | assert ('a' in ('x',1,None)) == 0 | 
| Guido van Rossum | d4d2684 | 2000-03-13 23:21:48 +0000 | [diff] [blame] | 240 | print 'done.' | 
|  | 241 |  | 
| Guido van Rossum | a831cac | 2000-03-10 23:23:21 +0000 | [diff] [blame] | 242 | # Formatting: | 
|  | 243 | print 'Testing Unicode formatting strings...', | 
|  | 244 | assert u"%s, %s" % (u"abc", "abc") == u'abc, abc' | 
|  | 245 | assert u"%s, %s, %i, %f, %5.2f" % (u"abc", "abc", 1, 2, 3) == u'abc, abc, 1, 2.000000,  3.00' | 
|  | 246 | assert u"%s, %s, %i, %f, %5.2f" % (u"abc", "abc", 1, -2, 3) == u'abc, abc, 1, -2.000000,  3.00' | 
|  | 247 | assert u"%s, %s, %i, %f, %5.2f" % (u"abc", "abc", -1, -2, 3.5) == u'abc, abc, -1, -2.000000,  3.50' | 
|  | 248 | assert u"%s, %s, %i, %f, %5.2f" % (u"abc", "abc", -1, -2, 3.57) == u'abc, abc, -1, -2.000000,  3.57' | 
|  | 249 | assert u"%s, %s, %i, %f, %5.2f" % (u"abc", "abc", -1, -2, 1003.57) == u'abc, abc, -1, -2.000000, 1003.57' | 
| Marc-André Lemburg | 59a044b | 2000-06-08 17:50:55 +0000 | [diff] [blame] | 250 | assert u"%c" % (u"a",) == u'a' | 
|  | 251 | assert u"%c" % ("a",) == u'a' | 
| Guido van Rossum | a831cac | 2000-03-10 23:23:21 +0000 | [diff] [blame] | 252 | assert u"%c" % (34,) == u'"' | 
|  | 253 | assert u"%c" % (36,) == u'$' | 
| Marc-André Lemburg | 8462573 | 2000-06-13 12:05:36 +0000 | [diff] [blame] | 254 | value = u"%r, %r" % (u"abc", "abc") | 
|  | 255 | if value != u"u'abc', 'abc'": | 
|  | 256 | print '*** formatting failed for "%s"' % 'u"%r, %r" % (u"abc", "abc")' | 
|  | 257 |  | 
| Guido van Rossum | a831cac | 2000-03-10 23:23:21 +0000 | [diff] [blame] | 258 | assert u"%(x)s, %(y)s" % {'x':u"abc", 'y':"def"} == u'abc, def' | 
| Marc-André Lemburg | 8462573 | 2000-06-13 12:05:36 +0000 | [diff] [blame] | 259 | try: | 
|  | 260 | value = u"%(x)s, %(ä)s" % {'x':u"abc", u'ä'.encode('utf-8'):"def"} | 
|  | 261 | except KeyError: | 
|  | 262 | print '*** formatting failed for "%s"' % "u'abc, def'" | 
|  | 263 | else: | 
|  | 264 | assert value == u'abc, def' | 
|  | 265 |  | 
| Guido van Rossum | 9706486 | 2000-04-10 13:52:48 +0000 | [diff] [blame] | 266 | # formatting jobs delegated from the string implementation: | 
|  | 267 | assert '...%(foo)s...' % {'foo':u"abc"} == u'...abc...' | 
|  | 268 | assert '...%(foo)s...' % {'foo':"abc"} == '...abc...' | 
|  | 269 | assert '...%(foo)s...' % {u'foo':"abc"} == '...abc...' | 
|  | 270 | assert '...%(foo)s...' % {u'foo':u"abc"} == u'...abc...' | 
|  | 271 | assert '...%(foo)s...' % {u'foo':u"abc",'def':123} ==  u'...abc...' | 
|  | 272 | assert '...%(foo)s...' % {u'foo':u"abc",u'def':123} == u'...abc...' | 
|  | 273 | assert '...%s...%s...%s...%s...' % (1,2,3,u"abc") == u'...1...2...3...abc...' | 
|  | 274 | assert '...%s...' % u"abc" == u'...abc...' | 
| Guido van Rossum | a831cac | 2000-03-10 23:23:21 +0000 | [diff] [blame] | 275 | print 'done.' | 
|  | 276 |  | 
| Guido van Rossum | d8855fd | 2000-03-24 22:14:19 +0000 | [diff] [blame] | 277 | # Test builtin codecs | 
|  | 278 | print 'Testing builtin codecs...', | 
|  | 279 |  | 
|  | 280 | assert unicode('hello','ascii') == u'hello' | 
|  | 281 | assert unicode('hello','utf-8') == u'hello' | 
|  | 282 | assert unicode('hello','utf8') == u'hello' | 
|  | 283 | assert unicode('hello','latin-1') == u'hello' | 
|  | 284 |  | 
| Guido van Rossum | 9706486 | 2000-04-10 13:52:48 +0000 | [diff] [blame] | 285 | try: | 
|  | 286 | u'Andr\202 x'.encode('ascii') | 
|  | 287 | u'Andr\202 x'.encode('ascii','strict') | 
|  | 288 | except ValueError: | 
|  | 289 | pass | 
|  | 290 | else: | 
|  | 291 | raise AssertionError, "u'Andr\202'.encode('ascii') failed to raise an exception" | 
|  | 292 | assert u'Andr\202 x'.encode('ascii','ignore') == "Andr x" | 
|  | 293 | assert u'Andr\202 x'.encode('ascii','replace') == "Andr? x" | 
|  | 294 |  | 
|  | 295 | try: | 
|  | 296 | unicode('Andr\202 x','ascii') | 
|  | 297 | unicode('Andr\202 x','ascii','strict') | 
|  | 298 | except ValueError: | 
|  | 299 | pass | 
|  | 300 | else: | 
|  | 301 | raise AssertionError, "unicode('Andr\202') failed to raise an exception" | 
|  | 302 | assert unicode('Andr\202 x','ascii','ignore') == u"Andr x" | 
|  | 303 | assert unicode('Andr\202 x','ascii','replace') == u'Andr\uFFFD x' | 
|  | 304 |  | 
| Guido van Rossum | d8855fd | 2000-03-24 22:14:19 +0000 | [diff] [blame] | 305 | assert u'hello'.encode('ascii') == 'hello' | 
|  | 306 | assert u'hello'.encode('utf-8') == 'hello' | 
|  | 307 | assert u'hello'.encode('utf8') == 'hello' | 
|  | 308 | assert u'hello'.encode('utf-16-le') == 'h\000e\000l\000l\000o\000' | 
|  | 309 | assert u'hello'.encode('utf-16-be') == '\000h\000e\000l\000l\000o' | 
|  | 310 | assert u'hello'.encode('latin-1') == 'hello' | 
|  | 311 |  | 
|  | 312 | u = u''.join(map(unichr, range(1024))) | 
|  | 313 | for encoding in ('utf-8', 'utf-16', 'utf-16-le', 'utf-16-be', | 
|  | 314 | 'raw_unicode_escape', 'unicode_escape', 'unicode_internal'): | 
|  | 315 | assert unicode(u.encode(encoding),encoding) == u | 
|  | 316 |  | 
|  | 317 | u = u''.join(map(unichr, range(256))) | 
| Guido van Rossum | 9e896b3 | 2000-04-05 20:11:21 +0000 | [diff] [blame] | 318 | for encoding in ( | 
|  | 319 | 'latin-1', | 
|  | 320 | ): | 
|  | 321 | try: | 
|  | 322 | assert unicode(u.encode(encoding),encoding) == u | 
|  | 323 | except AssertionError: | 
|  | 324 | print '*** codec "%s" failed round-trip' % encoding | 
|  | 325 | except ValueError,why: | 
|  | 326 | print '*** codec for "%s" failed: %s' % (encoding, why) | 
| Guido van Rossum | d8855fd | 2000-03-24 22:14:19 +0000 | [diff] [blame] | 327 |  | 
|  | 328 | u = u''.join(map(unichr, range(128))) | 
| Guido van Rossum | 9e896b3 | 2000-04-05 20:11:21 +0000 | [diff] [blame] | 329 | for encoding in ( | 
|  | 330 | 'ascii', | 
|  | 331 | ): | 
|  | 332 | try: | 
|  | 333 | assert unicode(u.encode(encoding),encoding) == u | 
|  | 334 | except AssertionError: | 
|  | 335 | print '*** codec "%s" failed round-trip' % encoding | 
|  | 336 | except ValueError,why: | 
|  | 337 | print '*** codec for "%s" failed: %s' % (encoding, why) | 
|  | 338 |  | 
|  | 339 | print 'done.' | 
|  | 340 |  | 
|  | 341 | print 'Testing standard mapping codecs...', | 
|  | 342 |  | 
|  | 343 | print '0-127...', | 
|  | 344 | s = ''.join(map(chr, range(128))) | 
|  | 345 | for encoding in ( | 
|  | 346 | 'cp037', 'cp1026', | 
|  | 347 | 'cp437', 'cp500', 'cp737', 'cp775', 'cp850', | 
|  | 348 | 'cp852', 'cp855', 'cp860', 'cp861', 'cp862', | 
|  | 349 | 'cp863', 'cp865', 'cp866', | 
|  | 350 | 'iso8859_10', 'iso8859_13', 'iso8859_14', 'iso8859_15', | 
|  | 351 | 'iso8859_2', 'iso8859_3', 'iso8859_4', 'iso8859_5', 'iso8859_6', | 
|  | 352 | 'iso8859_7', 'iso8859_9', 'koi8_r', 'latin_1', | 
|  | 353 | 'mac_cyrillic', 'mac_latin2', | 
|  | 354 |  | 
|  | 355 | 'cp1250', 'cp1251', 'cp1252', 'cp1253', 'cp1254', 'cp1255', | 
|  | 356 | 'cp1256', 'cp1257', 'cp1258', | 
|  | 357 | 'cp856', 'cp857', 'cp864', 'cp869', 'cp874', | 
|  | 358 |  | 
|  | 359 | 'mac_greek', 'mac_iceland','mac_roman', 'mac_turkish', | 
|  | 360 | 'cp1006', 'cp875', 'iso8859_8', | 
|  | 361 |  | 
|  | 362 | ### These have undefined mappings: | 
|  | 363 | #'cp424', | 
|  | 364 |  | 
|  | 365 | ): | 
|  | 366 | try: | 
|  | 367 | assert unicode(s,encoding).encode(encoding) == s | 
|  | 368 | except AssertionError: | 
|  | 369 | print '*** codec "%s" failed round-trip' % encoding | 
|  | 370 | except ValueError,why: | 
|  | 371 | print '*** codec for "%s" failed: %s' % (encoding, why) | 
|  | 372 |  | 
|  | 373 | print '128-255...', | 
|  | 374 | s = ''.join(map(chr, range(128,256))) | 
|  | 375 | for encoding in ( | 
|  | 376 | 'cp037', 'cp1026', | 
|  | 377 | 'cp437', 'cp500', 'cp737', 'cp775', 'cp850', | 
|  | 378 | 'cp852', 'cp855', 'cp860', 'cp861', 'cp862', | 
|  | 379 | 'cp863', 'cp865', 'cp866', | 
|  | 380 | 'iso8859_10', 'iso8859_13', 'iso8859_14', 'iso8859_15', | 
|  | 381 | 'iso8859_2', 'iso8859_3', 'iso8859_4', 'iso8859_5', 'iso8859_6', | 
|  | 382 | 'iso8859_7', 'iso8859_9', 'koi8_r', 'latin_1', | 
|  | 383 | 'mac_cyrillic', 'mac_latin2', | 
|  | 384 |  | 
|  | 385 | ### These have undefined mappings: | 
|  | 386 | #'cp1250', 'cp1251', 'cp1252', 'cp1253', 'cp1254', 'cp1255', | 
|  | 387 | #'cp1256', 'cp1257', 'cp1258', | 
|  | 388 | #'cp424', 'cp856', 'cp857', 'cp864', 'cp869', 'cp874', | 
|  | 389 | #'mac_greek', 'mac_iceland','mac_roman', 'mac_turkish', | 
|  | 390 |  | 
|  | 391 | ### These fail the round-trip: | 
|  | 392 | #'cp1006', 'cp875', 'iso8859_8', | 
|  | 393 |  | 
|  | 394 | ): | 
|  | 395 | try: | 
|  | 396 | assert unicode(s,encoding).encode(encoding) == s | 
|  | 397 | except AssertionError: | 
|  | 398 | print '*** codec "%s" failed round-trip' % encoding | 
|  | 399 | except ValueError,why: | 
|  | 400 | print '*** codec for "%s" failed: %s' % (encoding, why) | 
| Guido van Rossum | d8855fd | 2000-03-24 22:14:19 +0000 | [diff] [blame] | 401 |  | 
|  | 402 | print 'done.' | 
| Fred Drake | e0243e2 | 2000-04-13 14:11:56 +0000 | [diff] [blame] | 403 |  | 
|  | 404 | print 'Testing Unicode string concatenation...', | 
|  | 405 | assert (u"abc" u"def") == u"abcdef" | 
|  | 406 | assert ("abc" u"def") == u"abcdef" | 
|  | 407 | assert (u"abc" "def") == u"abcdef" | 
|  | 408 | assert (u"abc" u"def" "ghi") == u"abcdefghi" | 
|  | 409 | assert ("abc" "def" u"ghi") == u"abcdefghi" | 
|  | 410 | print 'done.' | 
| Marc-André Lemburg | a6f73d6 | 2000-06-28 16:41:23 +0000 | [diff] [blame^] | 411 |  | 
|  | 412 | print 'Testing General Unicode Character Name, and case insensitivity...', | 
|  | 413 | # General and case insensitivity test: | 
|  | 414 | s = u"\N{LATIN CAPITAL LETTER T}" \ | 
|  | 415 | u"\N{LATIN SMALL LETTER H}" \ | 
|  | 416 | u"\N{LATIN SMALL LETTER E}" \ | 
|  | 417 | u"\N{SPACE}" \ | 
|  | 418 | u"\N{LATIN SMALL LETTER R}" \ | 
|  | 419 | u"\N{LATIN CAPITAL LETTER E}" \ | 
|  | 420 | u"\N{LATIN SMALL LETTER D}" \ | 
|  | 421 | u"\N{SPACE}" \ | 
|  | 422 | u"\N{LATIN SMALL LETTER f}" \ | 
|  | 423 | u"\N{LATIN CAPITAL LeTtEr o}" \ | 
|  | 424 | u"\N{LATIN SMaLl LETTER x}" \ | 
|  | 425 | u"\N{SPACE}" \ | 
|  | 426 | u"\N{LATIN SMALL LETTER A}" \ | 
|  | 427 | u"\N{LATIN SMALL LETTER T}" \ | 
|  | 428 | u"\N{LATIN SMALL LETTER E}" \ | 
|  | 429 | u"\N{SPACE}" \ | 
|  | 430 | u"\N{LATIN SMALL LETTER T}" \ | 
|  | 431 | u"\N{LATIN SMALL LETTER H}" \ | 
|  | 432 | u"\N{LATIN SMALL LETTER E}" \ | 
|  | 433 | u"\N{SpAcE}" \ | 
|  | 434 | u"\N{LATIN SMALL LETTER S}" \ | 
|  | 435 | u"\N{LATIN SMALL LETTER H}" \ | 
|  | 436 | u"\N{LATIN SMALL LETTER E}" \ | 
|  | 437 | u"\N{LATIN SMALL LETTER E}" \ | 
|  | 438 | u"\N{LATIN SMALL LETTER P}" \ | 
|  | 439 | u"\N{FULL STOP}" | 
|  | 440 | assert s == u"The rEd fOx ate the sheep.", s | 
|  | 441 | print "done." | 
|  | 442 |  | 
|  | 443 | # misc. symbol testing | 
|  | 444 | print "Testing misc. symbols for unicode character name expansion....", | 
|  | 445 | assert u"\N{PILCROW SIGN}" == u"\u00b6" | 
|  | 446 | assert u"\N{REPLACEMENT CHARACTER}" == u"\uFFFD" | 
|  | 447 | assert u"\N{HALFWIDTH KATAKANA SEMI-VOICED SOUND MARK}" == u"\uFF9F" | 
|  | 448 | assert u"\N{FULLWIDTH LATIN SMALL LETTER A}" == u"\uFF41" | 
|  | 449 | print "done." | 
|  | 450 |  | 
|  | 451 |  | 
|  | 452 | # strict error testing: | 
|  | 453 | print "Testing unicode character name expansion strict error handling....", | 
|  | 454 | k_cchMaxUnicodeName = 83 | 
|  | 455 |  | 
|  | 456 | s = "\N{" + "1" * (k_cchMaxUnicodeName + 2) + "}" | 
|  | 457 | try: | 
|  | 458 | unicode(s, 'unicode-escape', 'strict') | 
|  | 459 | except UnicodeError: | 
|  | 460 | pass | 
|  | 461 | else: | 
|  | 462 | raise AssertionError, "failed to raise an exception when presented " \ | 
|  | 463 | "with a UCN > k_cchMaxUnicodeName" | 
|  | 464 | try: | 
|  | 465 | unicode("\N{blah}", 'unicode-escape', 'strict') | 
|  | 466 | except UnicodeError: | 
|  | 467 | pass | 
|  | 468 | else: | 
|  | 469 | raise AssertionError, "failed to raise an exception when given a bogus character name" | 
|  | 470 |  | 
|  | 471 | try: | 
|  | 472 | unicode("\N{SPACE", 'unicode-escape', 'strict') | 
|  | 473 | except UnicodeError: | 
|  | 474 | pass | 
|  | 475 | else: | 
|  | 476 | raise AssertionError, "failed to raise an exception for a missing closing brace." | 
|  | 477 |  | 
|  | 478 | try: | 
|  | 479 | unicode("\NSPACE", 'unicode-escape', 'strict') | 
|  | 480 | except UnicodeError: | 
|  | 481 | pass | 
|  | 482 | else: | 
|  | 483 | raise AssertionError, "failed to raise an exception for a missing opening brace." | 
|  | 484 | print "done." | 
|  | 485 |  |