fonttools/Tests/misc/encodingTools_test.py
Just van Rossum 5fc65d7168
Misc py23 cleanups (#2243)
* Replaced all from ...py23 import * with explicit name imports, or removed completely when possible.
* Replaced tounicode() with tostr()
* Changed all BytesIO ans StringIO imports to from io import ..., replaced all UnicodeIO with StringIO.
* Replaced all unichr() with chr()
* Misc minor tweaks and fixes
2021-03-29 11:45:58 +02:00

31 lines
1.0 KiB
Python

import unittest
from fontTools.misc.encodingTools import getEncoding
class EncodingTest(unittest.TestCase):
def test_encoding_unicode(self):
self.assertEqual(getEncoding(3, 0, None), "utf_16_be") # MS Symbol is Unicode as well
self.assertEqual(getEncoding(3, 1, None), "utf_16_be")
self.assertEqual(getEncoding(3, 10, None), "utf_16_be")
self.assertEqual(getEncoding(0, 3, None), "utf_16_be")
def test_encoding_macroman_misc(self):
self.assertEqual(getEncoding(1, 0, 17), "mac_turkish")
self.assertEqual(getEncoding(1, 0, 37), "mac_romanian")
self.assertEqual(getEncoding(1, 0, 45), "mac_roman")
def test_extended_mac_encodings(self):
encoding = getEncoding(1, 1, 0) # Mac Japanese
decoded = b'\xfe'.decode(encoding)
self.assertEqual(decoded, chr(0x2122))
def test_extended_unknown(self):
self.assertEqual(getEncoding(10, 11, 12), None)
self.assertEqual(getEncoding(10, 11, 12, "ascii"), "ascii")
self.assertEqual(getEncoding(10, 11, 12, default="ascii"), "ascii")
if __name__ == "__main__":
import sys
sys.exit(unittest.main())