mirror of
https://github.com/python/cpython.git
synced 2025-01-13 03:55:03 +08:00
2cded9c3f3
They only ignore the first byte of an invalid byte sequence. For example, b'\xff\n'.decode('gb2312', 'replace') gives '\ufffd\n' instead of '\ufffd'.
35 lines
918 B
Python
35 lines
918 B
Python
#!/usr/bin/env python3
|
|
#
|
|
# test_codecmaps_tw.py
|
|
# Codec mapping tests for ROC encodings
|
|
#
|
|
|
|
from test import support
|
|
from test import test_multibytecodec_support
|
|
import unittest
|
|
|
|
class TestBIG5Map(test_multibytecodec_support.TestBase_Mapping,
|
|
unittest.TestCase):
|
|
encoding = 'big5'
|
|
mapfileurl = 'http://www.unicode.org/Public/MAPPINGS/OBSOLETE/' \
|
|
'EASTASIA/OTHER/BIG5.TXT'
|
|
|
|
class TestCP950Map(test_multibytecodec_support.TestBase_Mapping,
|
|
unittest.TestCase):
|
|
encoding = 'cp950'
|
|
mapfileurl = 'http://www.unicode.org/Public/MAPPINGS/VENDORS/MICSFT/' \
|
|
'WINDOWS/CP950.TXT'
|
|
pass_enctest = [
|
|
(b'\xa2\xcc', '\u5341'),
|
|
(b'\xa2\xce', '\u5345'),
|
|
]
|
|
codectests = (
|
|
(b"\xFFxy", "replace", "\ufffdxy"),
|
|
)
|
|
|
|
def test_main():
|
|
support.run_unittest(__name__)
|
|
|
|
if __name__ == "__main__":
|
|
test_main()
|