17db96d56Sopenharmony_ci# Python test set -- built-in functions 27db96d56Sopenharmony_ci 37db96d56Sopenharmony_ciimport ast 47db96d56Sopenharmony_ciimport asyncio 57db96d56Sopenharmony_ciimport builtins 67db96d56Sopenharmony_ciimport collections 77db96d56Sopenharmony_ciimport decimal 87db96d56Sopenharmony_ciimport fractions 97db96d56Sopenharmony_ciimport gc 107db96d56Sopenharmony_ciimport io 117db96d56Sopenharmony_ciimport locale 127db96d56Sopenharmony_ciimport os 137db96d56Sopenharmony_ciimport pickle 147db96d56Sopenharmony_ciimport platform 157db96d56Sopenharmony_ciimport random 167db96d56Sopenharmony_ciimport re 177db96d56Sopenharmony_ciimport sys 187db96d56Sopenharmony_ciimport traceback 197db96d56Sopenharmony_ciimport types 207db96d56Sopenharmony_ciimport unittest 217db96d56Sopenharmony_ciimport warnings 227db96d56Sopenharmony_cifrom contextlib import ExitStack 237db96d56Sopenharmony_cifrom functools import partial 247db96d56Sopenharmony_cifrom inspect import CO_COROUTINE 257db96d56Sopenharmony_cifrom itertools import product 267db96d56Sopenharmony_cifrom textwrap import dedent 277db96d56Sopenharmony_cifrom types import AsyncGeneratorType, FunctionType, CellType 287db96d56Sopenharmony_cifrom operator import neg 297db96d56Sopenharmony_cifrom test import support 307db96d56Sopenharmony_cifrom test.support import (swap_attr, maybe_get_event_loop_policy) 317db96d56Sopenharmony_cifrom test.support.os_helper import (EnvironmentVarGuard, TESTFN, unlink) 327db96d56Sopenharmony_cifrom test.support.script_helper import assert_python_ok 337db96d56Sopenharmony_cifrom test.support.warnings_helper import check_warnings 347db96d56Sopenharmony_cifrom unittest.mock import MagicMock, patch 357db96d56Sopenharmony_citry: 367db96d56Sopenharmony_ci import pty, signal 377db96d56Sopenharmony_ciexcept ImportError: 387db96d56Sopenharmony_ci pty = signal = None 397db96d56Sopenharmony_ci 407db96d56Sopenharmony_ci 417db96d56Sopenharmony_ciclass Squares: 427db96d56Sopenharmony_ci 437db96d56Sopenharmony_ci def __init__(self, max): 447db96d56Sopenharmony_ci self.max = max 457db96d56Sopenharmony_ci self.sofar = [] 467db96d56Sopenharmony_ci 477db96d56Sopenharmony_ci def __len__(self): return len(self.sofar) 487db96d56Sopenharmony_ci 497db96d56Sopenharmony_ci def __getitem__(self, i): 507db96d56Sopenharmony_ci if not 0 <= i < self.max: raise IndexError 517db96d56Sopenharmony_ci n = len(self.sofar) 527db96d56Sopenharmony_ci while n <= i: 537db96d56Sopenharmony_ci self.sofar.append(n*n) 547db96d56Sopenharmony_ci n += 1 557db96d56Sopenharmony_ci return self.sofar[i] 567db96d56Sopenharmony_ci 577db96d56Sopenharmony_ciclass StrSquares: 587db96d56Sopenharmony_ci 597db96d56Sopenharmony_ci def __init__(self, max): 607db96d56Sopenharmony_ci self.max = max 617db96d56Sopenharmony_ci self.sofar = [] 627db96d56Sopenharmony_ci 637db96d56Sopenharmony_ci def __len__(self): 647db96d56Sopenharmony_ci return len(self.sofar) 657db96d56Sopenharmony_ci 667db96d56Sopenharmony_ci def __getitem__(self, i): 677db96d56Sopenharmony_ci if not 0 <= i < self.max: 687db96d56Sopenharmony_ci raise IndexError 697db96d56Sopenharmony_ci n = len(self.sofar) 707db96d56Sopenharmony_ci while n <= i: 717db96d56Sopenharmony_ci self.sofar.append(str(n*n)) 727db96d56Sopenharmony_ci n += 1 737db96d56Sopenharmony_ci return self.sofar[i] 747db96d56Sopenharmony_ci 757db96d56Sopenharmony_ciclass BitBucket: 767db96d56Sopenharmony_ci def write(self, line): 777db96d56Sopenharmony_ci pass 787db96d56Sopenharmony_ci 797db96d56Sopenharmony_citest_conv_no_sign = [ 807db96d56Sopenharmony_ci ('0', 0), 817db96d56Sopenharmony_ci ('1', 1), 827db96d56Sopenharmony_ci ('9', 9), 837db96d56Sopenharmony_ci ('10', 10), 847db96d56Sopenharmony_ci ('99', 99), 857db96d56Sopenharmony_ci ('100', 100), 867db96d56Sopenharmony_ci ('314', 314), 877db96d56Sopenharmony_ci (' 314', 314), 887db96d56Sopenharmony_ci ('314 ', 314), 897db96d56Sopenharmony_ci (' \t\t 314 \t\t ', 314), 907db96d56Sopenharmony_ci (repr(sys.maxsize), sys.maxsize), 917db96d56Sopenharmony_ci (' 1x', ValueError), 927db96d56Sopenharmony_ci (' 1 ', 1), 937db96d56Sopenharmony_ci (' 1\02 ', ValueError), 947db96d56Sopenharmony_ci ('', ValueError), 957db96d56Sopenharmony_ci (' ', ValueError), 967db96d56Sopenharmony_ci (' \t\t ', ValueError), 977db96d56Sopenharmony_ci (str(br'\u0663\u0661\u0664 ','raw-unicode-escape'), 314), 987db96d56Sopenharmony_ci (chr(0x200), ValueError), 997db96d56Sopenharmony_ci] 1007db96d56Sopenharmony_ci 1017db96d56Sopenharmony_citest_conv_sign = [ 1027db96d56Sopenharmony_ci ('0', 0), 1037db96d56Sopenharmony_ci ('1', 1), 1047db96d56Sopenharmony_ci ('9', 9), 1057db96d56Sopenharmony_ci ('10', 10), 1067db96d56Sopenharmony_ci ('99', 99), 1077db96d56Sopenharmony_ci ('100', 100), 1087db96d56Sopenharmony_ci ('314', 314), 1097db96d56Sopenharmony_ci (' 314', ValueError), 1107db96d56Sopenharmony_ci ('314 ', 314), 1117db96d56Sopenharmony_ci (' \t\t 314 \t\t ', ValueError), 1127db96d56Sopenharmony_ci (repr(sys.maxsize), sys.maxsize), 1137db96d56Sopenharmony_ci (' 1x', ValueError), 1147db96d56Sopenharmony_ci (' 1 ', ValueError), 1157db96d56Sopenharmony_ci (' 1\02 ', ValueError), 1167db96d56Sopenharmony_ci ('', ValueError), 1177db96d56Sopenharmony_ci (' ', ValueError), 1187db96d56Sopenharmony_ci (' \t\t ', ValueError), 1197db96d56Sopenharmony_ci (str(br'\u0663\u0661\u0664 ','raw-unicode-escape'), 314), 1207db96d56Sopenharmony_ci (chr(0x200), ValueError), 1217db96d56Sopenharmony_ci] 1227db96d56Sopenharmony_ci 1237db96d56Sopenharmony_ciclass TestFailingBool: 1247db96d56Sopenharmony_ci def __bool__(self): 1257db96d56Sopenharmony_ci raise RuntimeError 1267db96d56Sopenharmony_ci 1277db96d56Sopenharmony_ciclass TestFailingIter: 1287db96d56Sopenharmony_ci def __iter__(self): 1297db96d56Sopenharmony_ci raise RuntimeError 1307db96d56Sopenharmony_ci 1317db96d56Sopenharmony_cidef filter_char(arg): 1327db96d56Sopenharmony_ci return ord(arg) > ord("d") 1337db96d56Sopenharmony_ci 1347db96d56Sopenharmony_cidef map_char(arg): 1357db96d56Sopenharmony_ci return chr(ord(arg)+1) 1367db96d56Sopenharmony_ci 1377db96d56Sopenharmony_ciclass BuiltinTest(unittest.TestCase): 1387db96d56Sopenharmony_ci # Helper to check picklability 1397db96d56Sopenharmony_ci def check_iter_pickle(self, it, seq, proto): 1407db96d56Sopenharmony_ci itorg = it 1417db96d56Sopenharmony_ci d = pickle.dumps(it, proto) 1427db96d56Sopenharmony_ci it = pickle.loads(d) 1437db96d56Sopenharmony_ci self.assertEqual(type(itorg), type(it)) 1447db96d56Sopenharmony_ci self.assertEqual(list(it), seq) 1457db96d56Sopenharmony_ci 1467db96d56Sopenharmony_ci #test the iterator after dropping one from it 1477db96d56Sopenharmony_ci it = pickle.loads(d) 1487db96d56Sopenharmony_ci try: 1497db96d56Sopenharmony_ci next(it) 1507db96d56Sopenharmony_ci except StopIteration: 1517db96d56Sopenharmony_ci return 1527db96d56Sopenharmony_ci d = pickle.dumps(it, proto) 1537db96d56Sopenharmony_ci it = pickle.loads(d) 1547db96d56Sopenharmony_ci self.assertEqual(list(it), seq[1:]) 1557db96d56Sopenharmony_ci 1567db96d56Sopenharmony_ci def test_import(self): 1577db96d56Sopenharmony_ci __import__('sys') 1587db96d56Sopenharmony_ci __import__('time') 1597db96d56Sopenharmony_ci __import__('string') 1607db96d56Sopenharmony_ci __import__(name='sys') 1617db96d56Sopenharmony_ci __import__(name='time', level=0) 1627db96d56Sopenharmony_ci self.assertRaises(ModuleNotFoundError, __import__, 'spamspam') 1637db96d56Sopenharmony_ci self.assertRaises(TypeError, __import__, 1, 2, 3, 4) 1647db96d56Sopenharmony_ci self.assertRaises(ValueError, __import__, '') 1657db96d56Sopenharmony_ci self.assertRaises(TypeError, __import__, 'sys', name='sys') 1667db96d56Sopenharmony_ci # Relative import outside of a package with no __package__ or __spec__ (bpo-37409). 1677db96d56Sopenharmony_ci with self.assertWarns(ImportWarning): 1687db96d56Sopenharmony_ci self.assertRaises(ImportError, __import__, '', 1697db96d56Sopenharmony_ci {'__package__': None, '__spec__': None, '__name__': '__main__'}, 1707db96d56Sopenharmony_ci locals={}, fromlist=('foo',), level=1) 1717db96d56Sopenharmony_ci # embedded null character 1727db96d56Sopenharmony_ci self.assertRaises(ModuleNotFoundError, __import__, 'string\x00') 1737db96d56Sopenharmony_ci 1747db96d56Sopenharmony_ci def test_abs(self): 1757db96d56Sopenharmony_ci # int 1767db96d56Sopenharmony_ci self.assertEqual(abs(0), 0) 1777db96d56Sopenharmony_ci self.assertEqual(abs(1234), 1234) 1787db96d56Sopenharmony_ci self.assertEqual(abs(-1234), 1234) 1797db96d56Sopenharmony_ci self.assertTrue(abs(-sys.maxsize-1) > 0) 1807db96d56Sopenharmony_ci # float 1817db96d56Sopenharmony_ci self.assertEqual(abs(0.0), 0.0) 1827db96d56Sopenharmony_ci self.assertEqual(abs(3.14), 3.14) 1837db96d56Sopenharmony_ci self.assertEqual(abs(-3.14), 3.14) 1847db96d56Sopenharmony_ci # str 1857db96d56Sopenharmony_ci self.assertRaises(TypeError, abs, 'a') 1867db96d56Sopenharmony_ci # bool 1877db96d56Sopenharmony_ci self.assertEqual(abs(True), 1) 1887db96d56Sopenharmony_ci self.assertEqual(abs(False), 0) 1897db96d56Sopenharmony_ci # other 1907db96d56Sopenharmony_ci self.assertRaises(TypeError, abs) 1917db96d56Sopenharmony_ci self.assertRaises(TypeError, abs, None) 1927db96d56Sopenharmony_ci class AbsClass(object): 1937db96d56Sopenharmony_ci def __abs__(self): 1947db96d56Sopenharmony_ci return -5 1957db96d56Sopenharmony_ci self.assertEqual(abs(AbsClass()), -5) 1967db96d56Sopenharmony_ci 1977db96d56Sopenharmony_ci def test_all(self): 1987db96d56Sopenharmony_ci self.assertEqual(all([2, 4, 6]), True) 1997db96d56Sopenharmony_ci self.assertEqual(all([2, None, 6]), False) 2007db96d56Sopenharmony_ci self.assertRaises(RuntimeError, all, [2, TestFailingBool(), 6]) 2017db96d56Sopenharmony_ci self.assertRaises(RuntimeError, all, TestFailingIter()) 2027db96d56Sopenharmony_ci self.assertRaises(TypeError, all, 10) # Non-iterable 2037db96d56Sopenharmony_ci self.assertRaises(TypeError, all) # No args 2047db96d56Sopenharmony_ci self.assertRaises(TypeError, all, [2, 4, 6], []) # Too many args 2057db96d56Sopenharmony_ci self.assertEqual(all([]), True) # Empty iterator 2067db96d56Sopenharmony_ci self.assertEqual(all([0, TestFailingBool()]), False)# Short-circuit 2077db96d56Sopenharmony_ci S = [50, 60] 2087db96d56Sopenharmony_ci self.assertEqual(all(x > 42 for x in S), True) 2097db96d56Sopenharmony_ci S = [50, 40, 60] 2107db96d56Sopenharmony_ci self.assertEqual(all(x > 42 for x in S), False) 2117db96d56Sopenharmony_ci 2127db96d56Sopenharmony_ci def test_any(self): 2137db96d56Sopenharmony_ci self.assertEqual(any([None, None, None]), False) 2147db96d56Sopenharmony_ci self.assertEqual(any([None, 4, None]), True) 2157db96d56Sopenharmony_ci self.assertRaises(RuntimeError, any, [None, TestFailingBool(), 6]) 2167db96d56Sopenharmony_ci self.assertRaises(RuntimeError, any, TestFailingIter()) 2177db96d56Sopenharmony_ci self.assertRaises(TypeError, any, 10) # Non-iterable 2187db96d56Sopenharmony_ci self.assertRaises(TypeError, any) # No args 2197db96d56Sopenharmony_ci self.assertRaises(TypeError, any, [2, 4, 6], []) # Too many args 2207db96d56Sopenharmony_ci self.assertEqual(any([]), False) # Empty iterator 2217db96d56Sopenharmony_ci self.assertEqual(any([1, TestFailingBool()]), True) # Short-circuit 2227db96d56Sopenharmony_ci S = [40, 60, 30] 2237db96d56Sopenharmony_ci self.assertEqual(any(x > 42 for x in S), True) 2247db96d56Sopenharmony_ci S = [10, 20, 30] 2257db96d56Sopenharmony_ci self.assertEqual(any(x > 42 for x in S), False) 2267db96d56Sopenharmony_ci 2277db96d56Sopenharmony_ci def test_ascii(self): 2287db96d56Sopenharmony_ci self.assertEqual(ascii(''), '\'\'') 2297db96d56Sopenharmony_ci self.assertEqual(ascii(0), '0') 2307db96d56Sopenharmony_ci self.assertEqual(ascii(()), '()') 2317db96d56Sopenharmony_ci self.assertEqual(ascii([]), '[]') 2327db96d56Sopenharmony_ci self.assertEqual(ascii({}), '{}') 2337db96d56Sopenharmony_ci a = [] 2347db96d56Sopenharmony_ci a.append(a) 2357db96d56Sopenharmony_ci self.assertEqual(ascii(a), '[[...]]') 2367db96d56Sopenharmony_ci a = {} 2377db96d56Sopenharmony_ci a[0] = a 2387db96d56Sopenharmony_ci self.assertEqual(ascii(a), '{0: {...}}') 2397db96d56Sopenharmony_ci # Advanced checks for unicode strings 2407db96d56Sopenharmony_ci def _check_uni(s): 2417db96d56Sopenharmony_ci self.assertEqual(ascii(s), repr(s)) 2427db96d56Sopenharmony_ci _check_uni("'") 2437db96d56Sopenharmony_ci _check_uni('"') 2447db96d56Sopenharmony_ci _check_uni('"\'') 2457db96d56Sopenharmony_ci _check_uni('\0') 2467db96d56Sopenharmony_ci _check_uni('\r\n\t .') 2477db96d56Sopenharmony_ci # Unprintable non-ASCII characters 2487db96d56Sopenharmony_ci _check_uni('\x85') 2497db96d56Sopenharmony_ci _check_uni('\u1fff') 2507db96d56Sopenharmony_ci _check_uni('\U00012fff') 2517db96d56Sopenharmony_ci # Lone surrogates 2527db96d56Sopenharmony_ci _check_uni('\ud800') 2537db96d56Sopenharmony_ci _check_uni('\udfff') 2547db96d56Sopenharmony_ci # Issue #9804: surrogates should be joined even for printable 2557db96d56Sopenharmony_ci # wide characters (UCS-2 builds). 2567db96d56Sopenharmony_ci self.assertEqual(ascii('\U0001d121'), "'\\U0001d121'") 2577db96d56Sopenharmony_ci # All together 2587db96d56Sopenharmony_ci s = "'\0\"\n\r\t abcd\x85é\U00012fff\uD800\U0001D121xxx." 2597db96d56Sopenharmony_ci self.assertEqual(ascii(s), 2607db96d56Sopenharmony_ci r"""'\'\x00"\n\r\t abcd\x85\xe9\U00012fff\ud800\U0001d121xxx.'""") 2617db96d56Sopenharmony_ci 2627db96d56Sopenharmony_ci def test_neg(self): 2637db96d56Sopenharmony_ci x = -sys.maxsize-1 2647db96d56Sopenharmony_ci self.assertTrue(isinstance(x, int)) 2657db96d56Sopenharmony_ci self.assertEqual(-x, sys.maxsize+1) 2667db96d56Sopenharmony_ci 2677db96d56Sopenharmony_ci def test_callable(self): 2687db96d56Sopenharmony_ci self.assertTrue(callable(len)) 2697db96d56Sopenharmony_ci self.assertFalse(callable("a")) 2707db96d56Sopenharmony_ci self.assertTrue(callable(callable)) 2717db96d56Sopenharmony_ci self.assertTrue(callable(lambda x, y: x + y)) 2727db96d56Sopenharmony_ci self.assertFalse(callable(__builtins__)) 2737db96d56Sopenharmony_ci def f(): pass 2747db96d56Sopenharmony_ci self.assertTrue(callable(f)) 2757db96d56Sopenharmony_ci 2767db96d56Sopenharmony_ci class C1: 2777db96d56Sopenharmony_ci def meth(self): pass 2787db96d56Sopenharmony_ci self.assertTrue(callable(C1)) 2797db96d56Sopenharmony_ci c = C1() 2807db96d56Sopenharmony_ci self.assertTrue(callable(c.meth)) 2817db96d56Sopenharmony_ci self.assertFalse(callable(c)) 2827db96d56Sopenharmony_ci 2837db96d56Sopenharmony_ci # __call__ is looked up on the class, not the instance 2847db96d56Sopenharmony_ci c.__call__ = None 2857db96d56Sopenharmony_ci self.assertFalse(callable(c)) 2867db96d56Sopenharmony_ci c.__call__ = lambda self: 0 2877db96d56Sopenharmony_ci self.assertFalse(callable(c)) 2887db96d56Sopenharmony_ci del c.__call__ 2897db96d56Sopenharmony_ci self.assertFalse(callable(c)) 2907db96d56Sopenharmony_ci 2917db96d56Sopenharmony_ci class C2(object): 2927db96d56Sopenharmony_ci def __call__(self): pass 2937db96d56Sopenharmony_ci c2 = C2() 2947db96d56Sopenharmony_ci self.assertTrue(callable(c2)) 2957db96d56Sopenharmony_ci c2.__call__ = None 2967db96d56Sopenharmony_ci self.assertTrue(callable(c2)) 2977db96d56Sopenharmony_ci class C3(C2): pass 2987db96d56Sopenharmony_ci c3 = C3() 2997db96d56Sopenharmony_ci self.assertTrue(callable(c3)) 3007db96d56Sopenharmony_ci 3017db96d56Sopenharmony_ci def test_chr(self): 3027db96d56Sopenharmony_ci self.assertEqual(chr(32), ' ') 3037db96d56Sopenharmony_ci self.assertEqual(chr(65), 'A') 3047db96d56Sopenharmony_ci self.assertEqual(chr(97), 'a') 3057db96d56Sopenharmony_ci self.assertEqual(chr(0xff), '\xff') 3067db96d56Sopenharmony_ci self.assertRaises(ValueError, chr, 1<<24) 3077db96d56Sopenharmony_ci self.assertEqual(chr(sys.maxunicode), 3087db96d56Sopenharmony_ci str('\\U0010ffff'.encode("ascii"), 'unicode-escape')) 3097db96d56Sopenharmony_ci self.assertRaises(TypeError, chr) 3107db96d56Sopenharmony_ci self.assertEqual(chr(0x0000FFFF), "\U0000FFFF") 3117db96d56Sopenharmony_ci self.assertEqual(chr(0x00010000), "\U00010000") 3127db96d56Sopenharmony_ci self.assertEqual(chr(0x00010001), "\U00010001") 3137db96d56Sopenharmony_ci self.assertEqual(chr(0x000FFFFE), "\U000FFFFE") 3147db96d56Sopenharmony_ci self.assertEqual(chr(0x000FFFFF), "\U000FFFFF") 3157db96d56Sopenharmony_ci self.assertEqual(chr(0x00100000), "\U00100000") 3167db96d56Sopenharmony_ci self.assertEqual(chr(0x00100001), "\U00100001") 3177db96d56Sopenharmony_ci self.assertEqual(chr(0x0010FFFE), "\U0010FFFE") 3187db96d56Sopenharmony_ci self.assertEqual(chr(0x0010FFFF), "\U0010FFFF") 3197db96d56Sopenharmony_ci self.assertRaises(ValueError, chr, -1) 3207db96d56Sopenharmony_ci self.assertRaises(ValueError, chr, 0x00110000) 3217db96d56Sopenharmony_ci self.assertRaises((OverflowError, ValueError), chr, 2**32) 3227db96d56Sopenharmony_ci 3237db96d56Sopenharmony_ci def test_cmp(self): 3247db96d56Sopenharmony_ci self.assertTrue(not hasattr(builtins, "cmp")) 3257db96d56Sopenharmony_ci 3267db96d56Sopenharmony_ci def test_compile(self): 3277db96d56Sopenharmony_ci compile('print(1)\n', '', 'exec') 3287db96d56Sopenharmony_ci bom = b'\xef\xbb\xbf' 3297db96d56Sopenharmony_ci compile(bom + b'print(1)\n', '', 'exec') 3307db96d56Sopenharmony_ci compile(source='pass', filename='?', mode='exec') 3317db96d56Sopenharmony_ci compile(dont_inherit=False, filename='tmp', source='0', mode='eval') 3327db96d56Sopenharmony_ci compile('pass', '?', dont_inherit=True, mode='exec') 3337db96d56Sopenharmony_ci compile(memoryview(b"text"), "name", "exec") 3347db96d56Sopenharmony_ci self.assertRaises(TypeError, compile) 3357db96d56Sopenharmony_ci self.assertRaises(ValueError, compile, 'print(42)\n', '<string>', 'badmode') 3367db96d56Sopenharmony_ci self.assertRaises(ValueError, compile, 'print(42)\n', '<string>', 'single', 0xff) 3377db96d56Sopenharmony_ci self.assertRaises(TypeError, compile, 'pass', '?', 'exec', 3387db96d56Sopenharmony_ci mode='eval', source='0', filename='tmp') 3397db96d56Sopenharmony_ci compile('print("\xe5")\n', '', 'exec') 3407db96d56Sopenharmony_ci self.assertRaises(SyntaxError, compile, chr(0), 'f', 'exec') 3417db96d56Sopenharmony_ci self.assertRaises(ValueError, compile, str('a = 1'), 'f', 'bad') 3427db96d56Sopenharmony_ci 3437db96d56Sopenharmony_ci # test the optimize argument 3447db96d56Sopenharmony_ci 3457db96d56Sopenharmony_ci codestr = '''def f(): 3467db96d56Sopenharmony_ci """doc""" 3477db96d56Sopenharmony_ci debug_enabled = False 3487db96d56Sopenharmony_ci if __debug__: 3497db96d56Sopenharmony_ci debug_enabled = True 3507db96d56Sopenharmony_ci try: 3517db96d56Sopenharmony_ci assert False 3527db96d56Sopenharmony_ci except AssertionError: 3537db96d56Sopenharmony_ci return (True, f.__doc__, debug_enabled, __debug__) 3547db96d56Sopenharmony_ci else: 3557db96d56Sopenharmony_ci return (False, f.__doc__, debug_enabled, __debug__) 3567db96d56Sopenharmony_ci ''' 3577db96d56Sopenharmony_ci def f(): """doc""" 3587db96d56Sopenharmony_ci values = [(-1, __debug__, f.__doc__, __debug__, __debug__), 3597db96d56Sopenharmony_ci (0, True, 'doc', True, True), 3607db96d56Sopenharmony_ci (1, False, 'doc', False, False), 3617db96d56Sopenharmony_ci (2, False, None, False, False)] 3627db96d56Sopenharmony_ci for optval, *expected in values: 3637db96d56Sopenharmony_ci # test both direct compilation and compilation via AST 3647db96d56Sopenharmony_ci codeobjs = [] 3657db96d56Sopenharmony_ci codeobjs.append(compile(codestr, "<test>", "exec", optimize=optval)) 3667db96d56Sopenharmony_ci tree = ast.parse(codestr) 3677db96d56Sopenharmony_ci codeobjs.append(compile(tree, "<test>", "exec", optimize=optval)) 3687db96d56Sopenharmony_ci for code in codeobjs: 3697db96d56Sopenharmony_ci ns = {} 3707db96d56Sopenharmony_ci exec(code, ns) 3717db96d56Sopenharmony_ci rv = ns['f']() 3727db96d56Sopenharmony_ci self.assertEqual(rv, tuple(expected)) 3737db96d56Sopenharmony_ci 3747db96d56Sopenharmony_ci def test_compile_top_level_await_no_coro(self): 3757db96d56Sopenharmony_ci """Make sure top level non-await codes get the correct coroutine flags""" 3767db96d56Sopenharmony_ci modes = ('single', 'exec') 3777db96d56Sopenharmony_ci code_samples = [ 3787db96d56Sopenharmony_ci '''def f():pass\n''', 3797db96d56Sopenharmony_ci '''[x for x in l]''', 3807db96d56Sopenharmony_ci '''{x for x in l}''', 3817db96d56Sopenharmony_ci '''(x for x in l)''', 3827db96d56Sopenharmony_ci '''{x:x for x in l}''', 3837db96d56Sopenharmony_ci ] 3847db96d56Sopenharmony_ci for mode, code_sample in product(modes, code_samples): 3857db96d56Sopenharmony_ci source = dedent(code_sample) 3867db96d56Sopenharmony_ci co = compile(source, 3877db96d56Sopenharmony_ci '?', 3887db96d56Sopenharmony_ci mode, 3897db96d56Sopenharmony_ci flags=ast.PyCF_ALLOW_TOP_LEVEL_AWAIT) 3907db96d56Sopenharmony_ci 3917db96d56Sopenharmony_ci self.assertNotEqual(co.co_flags & CO_COROUTINE, CO_COROUTINE, 3927db96d56Sopenharmony_ci msg=f"source={source} mode={mode}") 3937db96d56Sopenharmony_ci 3947db96d56Sopenharmony_ci 3957db96d56Sopenharmony_ci @unittest.skipIf( 3967db96d56Sopenharmony_ci support.is_emscripten or support.is_wasi, 3977db96d56Sopenharmony_ci "socket.accept is broken" 3987db96d56Sopenharmony_ci ) 3997db96d56Sopenharmony_ci def test_compile_top_level_await(self): 4007db96d56Sopenharmony_ci """Test whether code some top level await can be compiled. 4017db96d56Sopenharmony_ci 4027db96d56Sopenharmony_ci Make sure it compiles only with the PyCF_ALLOW_TOP_LEVEL_AWAIT flag 4037db96d56Sopenharmony_ci set, and make sure the generated code object has the CO_COROUTINE flag 4047db96d56Sopenharmony_ci set in order to execute it with `await eval(.....)` instead of exec, 4057db96d56Sopenharmony_ci or via a FunctionType. 4067db96d56Sopenharmony_ci """ 4077db96d56Sopenharmony_ci 4087db96d56Sopenharmony_ci # helper function just to check we can run top=level async-for 4097db96d56Sopenharmony_ci async def arange(n): 4107db96d56Sopenharmony_ci for i in range(n): 4117db96d56Sopenharmony_ci yield i 4127db96d56Sopenharmony_ci 4137db96d56Sopenharmony_ci modes = ('single', 'exec') 4147db96d56Sopenharmony_ci code_samples = [ 4157db96d56Sopenharmony_ci '''a = await asyncio.sleep(0, result=1)''', 4167db96d56Sopenharmony_ci '''async for i in arange(1): 4177db96d56Sopenharmony_ci a = 1''', 4187db96d56Sopenharmony_ci '''async with asyncio.Lock() as l: 4197db96d56Sopenharmony_ci a = 1''', 4207db96d56Sopenharmony_ci '''a = [x async for x in arange(2)][1]''', 4217db96d56Sopenharmony_ci '''a = 1 in {x async for x in arange(2)}''', 4227db96d56Sopenharmony_ci '''a = {x:1 async for x in arange(1)}[0]''', 4237db96d56Sopenharmony_ci '''a = [x async for x in arange(2) async for x in arange(2)][1]''', 4247db96d56Sopenharmony_ci '''a = [x async for x in (x async for x in arange(5))][1]''', 4257db96d56Sopenharmony_ci '''a, = [1 for x in {x async for x in arange(1)}]''', 4267db96d56Sopenharmony_ci '''a = [await asyncio.sleep(0, x) async for x in arange(2)][1]''' 4277db96d56Sopenharmony_ci ] 4287db96d56Sopenharmony_ci policy = maybe_get_event_loop_policy() 4297db96d56Sopenharmony_ci try: 4307db96d56Sopenharmony_ci for mode, code_sample in product(modes, code_samples): 4317db96d56Sopenharmony_ci source = dedent(code_sample) 4327db96d56Sopenharmony_ci with self.assertRaises( 4337db96d56Sopenharmony_ci SyntaxError, msg=f"source={source} mode={mode}"): 4347db96d56Sopenharmony_ci compile(source, '?', mode) 4357db96d56Sopenharmony_ci 4367db96d56Sopenharmony_ci co = compile(source, 4377db96d56Sopenharmony_ci '?', 4387db96d56Sopenharmony_ci mode, 4397db96d56Sopenharmony_ci flags=ast.PyCF_ALLOW_TOP_LEVEL_AWAIT) 4407db96d56Sopenharmony_ci 4417db96d56Sopenharmony_ci self.assertEqual(co.co_flags & CO_COROUTINE, CO_COROUTINE, 4427db96d56Sopenharmony_ci msg=f"source={source} mode={mode}") 4437db96d56Sopenharmony_ci 4447db96d56Sopenharmony_ci # test we can create and advance a function type 4457db96d56Sopenharmony_ci globals_ = {'asyncio': asyncio, 'a': 0, 'arange': arange} 4467db96d56Sopenharmony_ci async_f = FunctionType(co, globals_) 4477db96d56Sopenharmony_ci asyncio.run(async_f()) 4487db96d56Sopenharmony_ci self.assertEqual(globals_['a'], 1) 4497db96d56Sopenharmony_ci 4507db96d56Sopenharmony_ci # test we can await-eval, 4517db96d56Sopenharmony_ci globals_ = {'asyncio': asyncio, 'a': 0, 'arange': arange} 4527db96d56Sopenharmony_ci asyncio.run(eval(co, globals_)) 4537db96d56Sopenharmony_ci self.assertEqual(globals_['a'], 1) 4547db96d56Sopenharmony_ci finally: 4557db96d56Sopenharmony_ci asyncio.set_event_loop_policy(policy) 4567db96d56Sopenharmony_ci 4577db96d56Sopenharmony_ci def test_compile_top_level_await_invalid_cases(self): 4587db96d56Sopenharmony_ci # helper function just to check we can run top=level async-for 4597db96d56Sopenharmony_ci async def arange(n): 4607db96d56Sopenharmony_ci for i in range(n): 4617db96d56Sopenharmony_ci yield i 4627db96d56Sopenharmony_ci 4637db96d56Sopenharmony_ci modes = ('single', 'exec') 4647db96d56Sopenharmony_ci code_samples = [ 4657db96d56Sopenharmony_ci '''def f(): await arange(10)\n''', 4667db96d56Sopenharmony_ci '''def f(): [x async for x in arange(10)]\n''', 4677db96d56Sopenharmony_ci '''def f(): [await x async for x in arange(10)]\n''', 4687db96d56Sopenharmony_ci '''def f(): 4697db96d56Sopenharmony_ci async for i in arange(1): 4707db96d56Sopenharmony_ci a = 1 4717db96d56Sopenharmony_ci ''', 4727db96d56Sopenharmony_ci '''def f(): 4737db96d56Sopenharmony_ci async with asyncio.Lock() as l: 4747db96d56Sopenharmony_ci a = 1 4757db96d56Sopenharmony_ci ''' 4767db96d56Sopenharmony_ci ] 4777db96d56Sopenharmony_ci policy = maybe_get_event_loop_policy() 4787db96d56Sopenharmony_ci try: 4797db96d56Sopenharmony_ci for mode, code_sample in product(modes, code_samples): 4807db96d56Sopenharmony_ci source = dedent(code_sample) 4817db96d56Sopenharmony_ci with self.assertRaises( 4827db96d56Sopenharmony_ci SyntaxError, msg=f"source={source} mode={mode}"): 4837db96d56Sopenharmony_ci compile(source, '?', mode) 4847db96d56Sopenharmony_ci 4857db96d56Sopenharmony_ci with self.assertRaises( 4867db96d56Sopenharmony_ci SyntaxError, msg=f"source={source} mode={mode}"): 4877db96d56Sopenharmony_ci co = compile(source, 4887db96d56Sopenharmony_ci '?', 4897db96d56Sopenharmony_ci mode, 4907db96d56Sopenharmony_ci flags=ast.PyCF_ALLOW_TOP_LEVEL_AWAIT) 4917db96d56Sopenharmony_ci finally: 4927db96d56Sopenharmony_ci asyncio.set_event_loop_policy(policy) 4937db96d56Sopenharmony_ci 4947db96d56Sopenharmony_ci 4957db96d56Sopenharmony_ci def test_compile_async_generator(self): 4967db96d56Sopenharmony_ci """ 4977db96d56Sopenharmony_ci With the PyCF_ALLOW_TOP_LEVEL_AWAIT flag added in 3.8, we want to 4987db96d56Sopenharmony_ci make sure AsyncGenerators are still properly not marked with the 4997db96d56Sopenharmony_ci CO_COROUTINE flag. 5007db96d56Sopenharmony_ci """ 5017db96d56Sopenharmony_ci code = dedent("""async def ticker(): 5027db96d56Sopenharmony_ci for i in range(10): 5037db96d56Sopenharmony_ci yield i 5047db96d56Sopenharmony_ci await asyncio.sleep(0)""") 5057db96d56Sopenharmony_ci 5067db96d56Sopenharmony_ci co = compile(code, '?', 'exec', flags=ast.PyCF_ALLOW_TOP_LEVEL_AWAIT) 5077db96d56Sopenharmony_ci glob = {} 5087db96d56Sopenharmony_ci exec(co, glob) 5097db96d56Sopenharmony_ci self.assertEqual(type(glob['ticker']()), AsyncGeneratorType) 5107db96d56Sopenharmony_ci 5117db96d56Sopenharmony_ci def test_delattr(self): 5127db96d56Sopenharmony_ci sys.spam = 1 5137db96d56Sopenharmony_ci delattr(sys, 'spam') 5147db96d56Sopenharmony_ci self.assertRaises(TypeError, delattr) 5157db96d56Sopenharmony_ci self.assertRaises(TypeError, delattr, sys) 5167db96d56Sopenharmony_ci msg = r"^attribute name must be string, not 'int'$" 5177db96d56Sopenharmony_ci self.assertRaisesRegex(TypeError, msg, delattr, sys, 1) 5187db96d56Sopenharmony_ci 5197db96d56Sopenharmony_ci def test_dir(self): 5207db96d56Sopenharmony_ci # dir(wrong number of arguments) 5217db96d56Sopenharmony_ci self.assertRaises(TypeError, dir, 42, 42) 5227db96d56Sopenharmony_ci 5237db96d56Sopenharmony_ci # dir() - local scope 5247db96d56Sopenharmony_ci local_var = 1 5257db96d56Sopenharmony_ci self.assertIn('local_var', dir()) 5267db96d56Sopenharmony_ci 5277db96d56Sopenharmony_ci # dir(module) 5287db96d56Sopenharmony_ci self.assertIn('exit', dir(sys)) 5297db96d56Sopenharmony_ci 5307db96d56Sopenharmony_ci # dir(module_with_invalid__dict__) 5317db96d56Sopenharmony_ci class Foo(types.ModuleType): 5327db96d56Sopenharmony_ci __dict__ = 8 5337db96d56Sopenharmony_ci f = Foo("foo") 5347db96d56Sopenharmony_ci self.assertRaises(TypeError, dir, f) 5357db96d56Sopenharmony_ci 5367db96d56Sopenharmony_ci # dir(type) 5377db96d56Sopenharmony_ci self.assertIn("strip", dir(str)) 5387db96d56Sopenharmony_ci self.assertNotIn("__mro__", dir(str)) 5397db96d56Sopenharmony_ci 5407db96d56Sopenharmony_ci # dir(obj) 5417db96d56Sopenharmony_ci class Foo(object): 5427db96d56Sopenharmony_ci def __init__(self): 5437db96d56Sopenharmony_ci self.x = 7 5447db96d56Sopenharmony_ci self.y = 8 5457db96d56Sopenharmony_ci self.z = 9 5467db96d56Sopenharmony_ci f = Foo() 5477db96d56Sopenharmony_ci self.assertIn("y", dir(f)) 5487db96d56Sopenharmony_ci 5497db96d56Sopenharmony_ci # dir(obj_no__dict__) 5507db96d56Sopenharmony_ci class Foo(object): 5517db96d56Sopenharmony_ci __slots__ = [] 5527db96d56Sopenharmony_ci f = Foo() 5537db96d56Sopenharmony_ci self.assertIn("__repr__", dir(f)) 5547db96d56Sopenharmony_ci 5557db96d56Sopenharmony_ci # dir(obj_no__class__with__dict__) 5567db96d56Sopenharmony_ci # (an ugly trick to cause getattr(f, "__class__") to fail) 5577db96d56Sopenharmony_ci class Foo(object): 5587db96d56Sopenharmony_ci __slots__ = ["__class__", "__dict__"] 5597db96d56Sopenharmony_ci def __init__(self): 5607db96d56Sopenharmony_ci self.bar = "wow" 5617db96d56Sopenharmony_ci f = Foo() 5627db96d56Sopenharmony_ci self.assertNotIn("__repr__", dir(f)) 5637db96d56Sopenharmony_ci self.assertIn("bar", dir(f)) 5647db96d56Sopenharmony_ci 5657db96d56Sopenharmony_ci # dir(obj_using __dir__) 5667db96d56Sopenharmony_ci class Foo(object): 5677db96d56Sopenharmony_ci def __dir__(self): 5687db96d56Sopenharmony_ci return ["kan", "ga", "roo"] 5697db96d56Sopenharmony_ci f = Foo() 5707db96d56Sopenharmony_ci self.assertTrue(dir(f) == ["ga", "kan", "roo"]) 5717db96d56Sopenharmony_ci 5727db96d56Sopenharmony_ci # dir(obj__dir__tuple) 5737db96d56Sopenharmony_ci class Foo(object): 5747db96d56Sopenharmony_ci def __dir__(self): 5757db96d56Sopenharmony_ci return ("b", "c", "a") 5767db96d56Sopenharmony_ci res = dir(Foo()) 5777db96d56Sopenharmony_ci self.assertIsInstance(res, list) 5787db96d56Sopenharmony_ci self.assertTrue(res == ["a", "b", "c"]) 5797db96d56Sopenharmony_ci 5807db96d56Sopenharmony_ci # dir(obj__dir__not_sequence) 5817db96d56Sopenharmony_ci class Foo(object): 5827db96d56Sopenharmony_ci def __dir__(self): 5837db96d56Sopenharmony_ci return 7 5847db96d56Sopenharmony_ci f = Foo() 5857db96d56Sopenharmony_ci self.assertRaises(TypeError, dir, f) 5867db96d56Sopenharmony_ci 5877db96d56Sopenharmony_ci # dir(traceback) 5887db96d56Sopenharmony_ci try: 5897db96d56Sopenharmony_ci raise IndexError 5907db96d56Sopenharmony_ci except IndexError as e: 5917db96d56Sopenharmony_ci self.assertEqual(len(dir(e.__traceback__)), 4) 5927db96d56Sopenharmony_ci 5937db96d56Sopenharmony_ci # test that object has a __dir__() 5947db96d56Sopenharmony_ci self.assertEqual(sorted([].__dir__()), dir([])) 5957db96d56Sopenharmony_ci 5967db96d56Sopenharmony_ci def test_divmod(self): 5977db96d56Sopenharmony_ci self.assertEqual(divmod(12, 7), (1, 5)) 5987db96d56Sopenharmony_ci self.assertEqual(divmod(-12, 7), (-2, 2)) 5997db96d56Sopenharmony_ci self.assertEqual(divmod(12, -7), (-2, -2)) 6007db96d56Sopenharmony_ci self.assertEqual(divmod(-12, -7), (1, -5)) 6017db96d56Sopenharmony_ci 6027db96d56Sopenharmony_ci self.assertEqual(divmod(-sys.maxsize-1, -1), (sys.maxsize+1, 0)) 6037db96d56Sopenharmony_ci 6047db96d56Sopenharmony_ci for num, denom, exp_result in [ (3.25, 1.0, (3.0, 0.25)), 6057db96d56Sopenharmony_ci (-3.25, 1.0, (-4.0, 0.75)), 6067db96d56Sopenharmony_ci (3.25, -1.0, (-4.0, -0.75)), 6077db96d56Sopenharmony_ci (-3.25, -1.0, (3.0, -0.25))]: 6087db96d56Sopenharmony_ci result = divmod(num, denom) 6097db96d56Sopenharmony_ci self.assertAlmostEqual(result[0], exp_result[0]) 6107db96d56Sopenharmony_ci self.assertAlmostEqual(result[1], exp_result[1]) 6117db96d56Sopenharmony_ci 6127db96d56Sopenharmony_ci self.assertRaises(TypeError, divmod) 6137db96d56Sopenharmony_ci 6147db96d56Sopenharmony_ci def test_eval(self): 6157db96d56Sopenharmony_ci self.assertEqual(eval('1+1'), 2) 6167db96d56Sopenharmony_ci self.assertEqual(eval(' 1+1\n'), 2) 6177db96d56Sopenharmony_ci globals = {'a': 1, 'b': 2} 6187db96d56Sopenharmony_ci locals = {'b': 200, 'c': 300} 6197db96d56Sopenharmony_ci self.assertEqual(eval('a', globals) , 1) 6207db96d56Sopenharmony_ci self.assertEqual(eval('a', globals, locals), 1) 6217db96d56Sopenharmony_ci self.assertEqual(eval('b', globals, locals), 200) 6227db96d56Sopenharmony_ci self.assertEqual(eval('c', globals, locals), 300) 6237db96d56Sopenharmony_ci globals = {'a': 1, 'b': 2} 6247db96d56Sopenharmony_ci locals = {'b': 200, 'c': 300} 6257db96d56Sopenharmony_ci bom = b'\xef\xbb\xbf' 6267db96d56Sopenharmony_ci self.assertEqual(eval(bom + b'a', globals, locals), 1) 6277db96d56Sopenharmony_ci self.assertEqual(eval('"\xe5"', globals), "\xe5") 6287db96d56Sopenharmony_ci self.assertRaises(TypeError, eval) 6297db96d56Sopenharmony_ci self.assertRaises(TypeError, eval, ()) 6307db96d56Sopenharmony_ci self.assertRaises(SyntaxError, eval, bom[:2] + b'a') 6317db96d56Sopenharmony_ci 6327db96d56Sopenharmony_ci class X: 6337db96d56Sopenharmony_ci def __getitem__(self, key): 6347db96d56Sopenharmony_ci raise ValueError 6357db96d56Sopenharmony_ci self.assertRaises(ValueError, eval, "foo", {}, X()) 6367db96d56Sopenharmony_ci 6377db96d56Sopenharmony_ci def test_general_eval(self): 6387db96d56Sopenharmony_ci # Tests that general mappings can be used for the locals argument 6397db96d56Sopenharmony_ci 6407db96d56Sopenharmony_ci class M: 6417db96d56Sopenharmony_ci "Test mapping interface versus possible calls from eval()." 6427db96d56Sopenharmony_ci def __getitem__(self, key): 6437db96d56Sopenharmony_ci if key == 'a': 6447db96d56Sopenharmony_ci return 12 6457db96d56Sopenharmony_ci raise KeyError 6467db96d56Sopenharmony_ci def keys(self): 6477db96d56Sopenharmony_ci return list('xyz') 6487db96d56Sopenharmony_ci 6497db96d56Sopenharmony_ci m = M() 6507db96d56Sopenharmony_ci g = globals() 6517db96d56Sopenharmony_ci self.assertEqual(eval('a', g, m), 12) 6527db96d56Sopenharmony_ci self.assertRaises(NameError, eval, 'b', g, m) 6537db96d56Sopenharmony_ci self.assertEqual(eval('dir()', g, m), list('xyz')) 6547db96d56Sopenharmony_ci self.assertEqual(eval('globals()', g, m), g) 6557db96d56Sopenharmony_ci self.assertEqual(eval('locals()', g, m), m) 6567db96d56Sopenharmony_ci self.assertRaises(TypeError, eval, 'a', m) 6577db96d56Sopenharmony_ci class A: 6587db96d56Sopenharmony_ci "Non-mapping" 6597db96d56Sopenharmony_ci pass 6607db96d56Sopenharmony_ci m = A() 6617db96d56Sopenharmony_ci self.assertRaises(TypeError, eval, 'a', g, m) 6627db96d56Sopenharmony_ci 6637db96d56Sopenharmony_ci # Verify that dict subclasses work as well 6647db96d56Sopenharmony_ci class D(dict): 6657db96d56Sopenharmony_ci def __getitem__(self, key): 6667db96d56Sopenharmony_ci if key == 'a': 6677db96d56Sopenharmony_ci return 12 6687db96d56Sopenharmony_ci return dict.__getitem__(self, key) 6697db96d56Sopenharmony_ci def keys(self): 6707db96d56Sopenharmony_ci return list('xyz') 6717db96d56Sopenharmony_ci 6727db96d56Sopenharmony_ci d = D() 6737db96d56Sopenharmony_ci self.assertEqual(eval('a', g, d), 12) 6747db96d56Sopenharmony_ci self.assertRaises(NameError, eval, 'b', g, d) 6757db96d56Sopenharmony_ci self.assertEqual(eval('dir()', g, d), list('xyz')) 6767db96d56Sopenharmony_ci self.assertEqual(eval('globals()', g, d), g) 6777db96d56Sopenharmony_ci self.assertEqual(eval('locals()', g, d), d) 6787db96d56Sopenharmony_ci 6797db96d56Sopenharmony_ci # Verify locals stores (used by list comps) 6807db96d56Sopenharmony_ci eval('[locals() for i in (2,3)]', g, d) 6817db96d56Sopenharmony_ci eval('[locals() for i in (2,3)]', g, collections.UserDict()) 6827db96d56Sopenharmony_ci 6837db96d56Sopenharmony_ci class SpreadSheet: 6847db96d56Sopenharmony_ci "Sample application showing nested, calculated lookups." 6857db96d56Sopenharmony_ci _cells = {} 6867db96d56Sopenharmony_ci def __setitem__(self, key, formula): 6877db96d56Sopenharmony_ci self._cells[key] = formula 6887db96d56Sopenharmony_ci def __getitem__(self, key): 6897db96d56Sopenharmony_ci return eval(self._cells[key], globals(), self) 6907db96d56Sopenharmony_ci 6917db96d56Sopenharmony_ci ss = SpreadSheet() 6927db96d56Sopenharmony_ci ss['a1'] = '5' 6937db96d56Sopenharmony_ci ss['a2'] = 'a1*6' 6947db96d56Sopenharmony_ci ss['a3'] = 'a2*7' 6957db96d56Sopenharmony_ci self.assertEqual(ss['a3'], 210) 6967db96d56Sopenharmony_ci 6977db96d56Sopenharmony_ci # Verify that dir() catches a non-list returned by eval 6987db96d56Sopenharmony_ci # SF bug #1004669 6997db96d56Sopenharmony_ci class C: 7007db96d56Sopenharmony_ci def __getitem__(self, item): 7017db96d56Sopenharmony_ci raise KeyError(item) 7027db96d56Sopenharmony_ci def keys(self): 7037db96d56Sopenharmony_ci return 1 # used to be 'a' but that's no longer an error 7047db96d56Sopenharmony_ci self.assertRaises(TypeError, eval, 'dir()', globals(), C()) 7057db96d56Sopenharmony_ci 7067db96d56Sopenharmony_ci def test_exec(self): 7077db96d56Sopenharmony_ci g = {} 7087db96d56Sopenharmony_ci exec('z = 1', g) 7097db96d56Sopenharmony_ci if '__builtins__' in g: 7107db96d56Sopenharmony_ci del g['__builtins__'] 7117db96d56Sopenharmony_ci self.assertEqual(g, {'z': 1}) 7127db96d56Sopenharmony_ci 7137db96d56Sopenharmony_ci exec('z = 1+1', g) 7147db96d56Sopenharmony_ci if '__builtins__' in g: 7157db96d56Sopenharmony_ci del g['__builtins__'] 7167db96d56Sopenharmony_ci self.assertEqual(g, {'z': 2}) 7177db96d56Sopenharmony_ci g = {} 7187db96d56Sopenharmony_ci l = {} 7197db96d56Sopenharmony_ci 7207db96d56Sopenharmony_ci with check_warnings(): 7217db96d56Sopenharmony_ci warnings.filterwarnings("ignore", "global statement", 7227db96d56Sopenharmony_ci module="<string>") 7237db96d56Sopenharmony_ci exec('global a; a = 1; b = 2', g, l) 7247db96d56Sopenharmony_ci if '__builtins__' in g: 7257db96d56Sopenharmony_ci del g['__builtins__'] 7267db96d56Sopenharmony_ci if '__builtins__' in l: 7277db96d56Sopenharmony_ci del l['__builtins__'] 7287db96d56Sopenharmony_ci self.assertEqual((g, l), ({'a': 1}, {'b': 2})) 7297db96d56Sopenharmony_ci 7307db96d56Sopenharmony_ci def test_exec_globals(self): 7317db96d56Sopenharmony_ci code = compile("print('Hello World!')", "", "exec") 7327db96d56Sopenharmony_ci # no builtin function 7337db96d56Sopenharmony_ci self.assertRaisesRegex(NameError, "name 'print' is not defined", 7347db96d56Sopenharmony_ci exec, code, {'__builtins__': {}}) 7357db96d56Sopenharmony_ci # __builtins__ must be a mapping type 7367db96d56Sopenharmony_ci self.assertRaises(TypeError, 7377db96d56Sopenharmony_ci exec, code, {'__builtins__': 123}) 7387db96d56Sopenharmony_ci 7397db96d56Sopenharmony_ci def test_exec_globals_frozen(self): 7407db96d56Sopenharmony_ci class frozendict_error(Exception): 7417db96d56Sopenharmony_ci pass 7427db96d56Sopenharmony_ci 7437db96d56Sopenharmony_ci class frozendict(dict): 7447db96d56Sopenharmony_ci def __setitem__(self, key, value): 7457db96d56Sopenharmony_ci raise frozendict_error("frozendict is readonly") 7467db96d56Sopenharmony_ci 7477db96d56Sopenharmony_ci # read-only builtins 7487db96d56Sopenharmony_ci if isinstance(__builtins__, types.ModuleType): 7497db96d56Sopenharmony_ci frozen_builtins = frozendict(__builtins__.__dict__) 7507db96d56Sopenharmony_ci else: 7517db96d56Sopenharmony_ci frozen_builtins = frozendict(__builtins__) 7527db96d56Sopenharmony_ci code = compile("__builtins__['superglobal']=2; print(superglobal)", "test", "exec") 7537db96d56Sopenharmony_ci self.assertRaises(frozendict_error, 7547db96d56Sopenharmony_ci exec, code, {'__builtins__': frozen_builtins}) 7557db96d56Sopenharmony_ci 7567db96d56Sopenharmony_ci # no __build_class__ function 7577db96d56Sopenharmony_ci code = compile("class A: pass", "", "exec") 7587db96d56Sopenharmony_ci self.assertRaisesRegex(NameError, "__build_class__ not found", 7597db96d56Sopenharmony_ci exec, code, {'__builtins__': {}}) 7607db96d56Sopenharmony_ci # __build_class__ in a custom __builtins__ 7617db96d56Sopenharmony_ci exec(code, {'__builtins__': frozen_builtins}) 7627db96d56Sopenharmony_ci self.assertRaisesRegex(NameError, "__build_class__ not found", 7637db96d56Sopenharmony_ci exec, code, {'__builtins__': frozendict()}) 7647db96d56Sopenharmony_ci 7657db96d56Sopenharmony_ci # read-only globals 7667db96d56Sopenharmony_ci namespace = frozendict({}) 7677db96d56Sopenharmony_ci code = compile("x=1", "test", "exec") 7687db96d56Sopenharmony_ci self.assertRaises(frozendict_error, 7697db96d56Sopenharmony_ci exec, code, namespace) 7707db96d56Sopenharmony_ci 7717db96d56Sopenharmony_ci def test_exec_globals_error_on_get(self): 7727db96d56Sopenharmony_ci # custom `globals` or `builtins` can raise errors on item access 7737db96d56Sopenharmony_ci class setonlyerror(Exception): 7747db96d56Sopenharmony_ci pass 7757db96d56Sopenharmony_ci 7767db96d56Sopenharmony_ci class setonlydict(dict): 7777db96d56Sopenharmony_ci def __getitem__(self, key): 7787db96d56Sopenharmony_ci raise setonlyerror 7797db96d56Sopenharmony_ci 7807db96d56Sopenharmony_ci # globals' `__getitem__` raises 7817db96d56Sopenharmony_ci code = compile("globalname", "test", "exec") 7827db96d56Sopenharmony_ci self.assertRaises(setonlyerror, 7837db96d56Sopenharmony_ci exec, code, setonlydict({'globalname': 1})) 7847db96d56Sopenharmony_ci 7857db96d56Sopenharmony_ci # builtins' `__getitem__` raises 7867db96d56Sopenharmony_ci code = compile("superglobal", "test", "exec") 7877db96d56Sopenharmony_ci self.assertRaises(setonlyerror, exec, code, 7887db96d56Sopenharmony_ci {'__builtins__': setonlydict({'superglobal': 1})}) 7897db96d56Sopenharmony_ci 7907db96d56Sopenharmony_ci def test_exec_globals_dict_subclass(self): 7917db96d56Sopenharmony_ci class customdict(dict): # this one should not do anything fancy 7927db96d56Sopenharmony_ci pass 7937db96d56Sopenharmony_ci 7947db96d56Sopenharmony_ci code = compile("superglobal", "test", "exec") 7957db96d56Sopenharmony_ci # works correctly 7967db96d56Sopenharmony_ci exec(code, {'__builtins__': customdict({'superglobal': 1})}) 7977db96d56Sopenharmony_ci # custom builtins dict subclass is missing key 7987db96d56Sopenharmony_ci self.assertRaisesRegex(NameError, "name 'superglobal' is not defined", 7997db96d56Sopenharmony_ci exec, code, {'__builtins__': customdict()}) 8007db96d56Sopenharmony_ci 8017db96d56Sopenharmony_ci def test_exec_redirected(self): 8027db96d56Sopenharmony_ci savestdout = sys.stdout 8037db96d56Sopenharmony_ci sys.stdout = None # Whatever that cannot flush() 8047db96d56Sopenharmony_ci try: 8057db96d56Sopenharmony_ci # Used to raise SystemError('error return without exception set') 8067db96d56Sopenharmony_ci exec('a') 8077db96d56Sopenharmony_ci except NameError: 8087db96d56Sopenharmony_ci pass 8097db96d56Sopenharmony_ci finally: 8107db96d56Sopenharmony_ci sys.stdout = savestdout 8117db96d56Sopenharmony_ci 8127db96d56Sopenharmony_ci def test_exec_closure(self): 8137db96d56Sopenharmony_ci def function_without_closures(): 8147db96d56Sopenharmony_ci return 3 * 5 8157db96d56Sopenharmony_ci 8167db96d56Sopenharmony_ci result = 0 8177db96d56Sopenharmony_ci def make_closure_functions(): 8187db96d56Sopenharmony_ci a = 2 8197db96d56Sopenharmony_ci b = 3 8207db96d56Sopenharmony_ci c = 5 8217db96d56Sopenharmony_ci def three_freevars(): 8227db96d56Sopenharmony_ci nonlocal result 8237db96d56Sopenharmony_ci nonlocal a 8247db96d56Sopenharmony_ci nonlocal b 8257db96d56Sopenharmony_ci result = a*b 8267db96d56Sopenharmony_ci def four_freevars(): 8277db96d56Sopenharmony_ci nonlocal result 8287db96d56Sopenharmony_ci nonlocal a 8297db96d56Sopenharmony_ci nonlocal b 8307db96d56Sopenharmony_ci nonlocal c 8317db96d56Sopenharmony_ci result = a*b*c 8327db96d56Sopenharmony_ci return three_freevars, four_freevars 8337db96d56Sopenharmony_ci three_freevars, four_freevars = make_closure_functions() 8347db96d56Sopenharmony_ci 8357db96d56Sopenharmony_ci # "smoke" test 8367db96d56Sopenharmony_ci result = 0 8377db96d56Sopenharmony_ci exec(three_freevars.__code__, 8387db96d56Sopenharmony_ci three_freevars.__globals__, 8397db96d56Sopenharmony_ci closure=three_freevars.__closure__) 8407db96d56Sopenharmony_ci self.assertEqual(result, 6) 8417db96d56Sopenharmony_ci 8427db96d56Sopenharmony_ci # should also work with a manually created closure 8437db96d56Sopenharmony_ci result = 0 8447db96d56Sopenharmony_ci my_closure = (CellType(35), CellType(72), three_freevars.__closure__[2]) 8457db96d56Sopenharmony_ci exec(three_freevars.__code__, 8467db96d56Sopenharmony_ci three_freevars.__globals__, 8477db96d56Sopenharmony_ci closure=my_closure) 8487db96d56Sopenharmony_ci self.assertEqual(result, 2520) 8497db96d56Sopenharmony_ci 8507db96d56Sopenharmony_ci # should fail: closure isn't allowed 8517db96d56Sopenharmony_ci # for functions without free vars 8527db96d56Sopenharmony_ci self.assertRaises(TypeError, 8537db96d56Sopenharmony_ci exec, 8547db96d56Sopenharmony_ci function_without_closures.__code__, 8557db96d56Sopenharmony_ci function_without_closures.__globals__, 8567db96d56Sopenharmony_ci closure=my_closure) 8577db96d56Sopenharmony_ci 8587db96d56Sopenharmony_ci # should fail: closure required but wasn't specified 8597db96d56Sopenharmony_ci self.assertRaises(TypeError, 8607db96d56Sopenharmony_ci exec, 8617db96d56Sopenharmony_ci three_freevars.__code__, 8627db96d56Sopenharmony_ci three_freevars.__globals__, 8637db96d56Sopenharmony_ci closure=None) 8647db96d56Sopenharmony_ci 8657db96d56Sopenharmony_ci # should fail: closure of wrong length 8667db96d56Sopenharmony_ci self.assertRaises(TypeError, 8677db96d56Sopenharmony_ci exec, 8687db96d56Sopenharmony_ci three_freevars.__code__, 8697db96d56Sopenharmony_ci three_freevars.__globals__, 8707db96d56Sopenharmony_ci closure=four_freevars.__closure__) 8717db96d56Sopenharmony_ci 8727db96d56Sopenharmony_ci # should fail: closure using a list instead of a tuple 8737db96d56Sopenharmony_ci my_closure = list(my_closure) 8747db96d56Sopenharmony_ci self.assertRaises(TypeError, 8757db96d56Sopenharmony_ci exec, 8767db96d56Sopenharmony_ci three_freevars.__code__, 8777db96d56Sopenharmony_ci three_freevars.__globals__, 8787db96d56Sopenharmony_ci closure=my_closure) 8797db96d56Sopenharmony_ci 8807db96d56Sopenharmony_ci # should fail: closure tuple with one non-cell-var 8817db96d56Sopenharmony_ci my_closure[0] = int 8827db96d56Sopenharmony_ci my_closure = tuple(my_closure) 8837db96d56Sopenharmony_ci self.assertRaises(TypeError, 8847db96d56Sopenharmony_ci exec, 8857db96d56Sopenharmony_ci three_freevars.__code__, 8867db96d56Sopenharmony_ci three_freevars.__globals__, 8877db96d56Sopenharmony_ci closure=my_closure) 8887db96d56Sopenharmony_ci 8897db96d56Sopenharmony_ci 8907db96d56Sopenharmony_ci def test_filter(self): 8917db96d56Sopenharmony_ci self.assertEqual(list(filter(lambda c: 'a' <= c <= 'z', 'Hello World')), list('elloorld')) 8927db96d56Sopenharmony_ci self.assertEqual(list(filter(None, [1, 'hello', [], [3], '', None, 9, 0])), [1, 'hello', [3], 9]) 8937db96d56Sopenharmony_ci self.assertEqual(list(filter(lambda x: x > 0, [1, -3, 9, 0, 2])), [1, 9, 2]) 8947db96d56Sopenharmony_ci self.assertEqual(list(filter(None, Squares(10))), [1, 4, 9, 16, 25, 36, 49, 64, 81]) 8957db96d56Sopenharmony_ci self.assertEqual(list(filter(lambda x: x%2, Squares(10))), [1, 9, 25, 49, 81]) 8967db96d56Sopenharmony_ci def identity(item): 8977db96d56Sopenharmony_ci return 1 8987db96d56Sopenharmony_ci filter(identity, Squares(5)) 8997db96d56Sopenharmony_ci self.assertRaises(TypeError, filter) 9007db96d56Sopenharmony_ci class BadSeq(object): 9017db96d56Sopenharmony_ci def __getitem__(self, index): 9027db96d56Sopenharmony_ci if index<4: 9037db96d56Sopenharmony_ci return 42 9047db96d56Sopenharmony_ci raise ValueError 9057db96d56Sopenharmony_ci self.assertRaises(ValueError, list, filter(lambda x: x, BadSeq())) 9067db96d56Sopenharmony_ci def badfunc(): 9077db96d56Sopenharmony_ci pass 9087db96d56Sopenharmony_ci self.assertRaises(TypeError, list, filter(badfunc, range(5))) 9097db96d56Sopenharmony_ci 9107db96d56Sopenharmony_ci # test bltinmodule.c::filtertuple() 9117db96d56Sopenharmony_ci self.assertEqual(list(filter(None, (1, 2))), [1, 2]) 9127db96d56Sopenharmony_ci self.assertEqual(list(filter(lambda x: x>=3, (1, 2, 3, 4))), [3, 4]) 9137db96d56Sopenharmony_ci self.assertRaises(TypeError, list, filter(42, (1, 2))) 9147db96d56Sopenharmony_ci 9157db96d56Sopenharmony_ci def test_filter_pickle(self): 9167db96d56Sopenharmony_ci for proto in range(pickle.HIGHEST_PROTOCOL + 1): 9177db96d56Sopenharmony_ci f1 = filter(filter_char, "abcdeabcde") 9187db96d56Sopenharmony_ci f2 = filter(filter_char, "abcdeabcde") 9197db96d56Sopenharmony_ci self.check_iter_pickle(f1, list(f2), proto) 9207db96d56Sopenharmony_ci 9217db96d56Sopenharmony_ci def test_filter_dealloc(self): 9227db96d56Sopenharmony_ci # Tests recursive deallocation of nested filter objects using the 9237db96d56Sopenharmony_ci # thrashcan mechanism. See gh-102356 for more details. 9247db96d56Sopenharmony_ci max_iters = 1000000 9257db96d56Sopenharmony_ci i = filter(bool, range(max_iters)) 9267db96d56Sopenharmony_ci for _ in range(max_iters): 9277db96d56Sopenharmony_ci i = filter(bool, i) 9287db96d56Sopenharmony_ci del i 9297db96d56Sopenharmony_ci gc.collect() 9307db96d56Sopenharmony_ci 9317db96d56Sopenharmony_ci def test_getattr(self): 9327db96d56Sopenharmony_ci self.assertTrue(getattr(sys, 'stdout') is sys.stdout) 9337db96d56Sopenharmony_ci self.assertRaises(TypeError, getattr) 9347db96d56Sopenharmony_ci self.assertRaises(TypeError, getattr, sys) 9357db96d56Sopenharmony_ci msg = r"^attribute name must be string, not 'int'$" 9367db96d56Sopenharmony_ci self.assertRaisesRegex(TypeError, msg, getattr, sys, 1) 9377db96d56Sopenharmony_ci self.assertRaisesRegex(TypeError, msg, getattr, sys, 1, 'spam') 9387db96d56Sopenharmony_ci self.assertRaises(AttributeError, getattr, sys, chr(sys.maxunicode)) 9397db96d56Sopenharmony_ci # unicode surrogates are not encodable to the default encoding (utf8) 9407db96d56Sopenharmony_ci self.assertRaises(AttributeError, getattr, 1, "\uDAD1\uD51E") 9417db96d56Sopenharmony_ci 9427db96d56Sopenharmony_ci def test_hasattr(self): 9437db96d56Sopenharmony_ci self.assertTrue(hasattr(sys, 'stdout')) 9447db96d56Sopenharmony_ci self.assertRaises(TypeError, hasattr) 9457db96d56Sopenharmony_ci self.assertRaises(TypeError, hasattr, sys) 9467db96d56Sopenharmony_ci msg = r"^attribute name must be string, not 'int'$" 9477db96d56Sopenharmony_ci self.assertRaisesRegex(TypeError, msg, hasattr, sys, 1) 9487db96d56Sopenharmony_ci self.assertEqual(False, hasattr(sys, chr(sys.maxunicode))) 9497db96d56Sopenharmony_ci 9507db96d56Sopenharmony_ci # Check that hasattr propagates all exceptions outside of 9517db96d56Sopenharmony_ci # AttributeError. 9527db96d56Sopenharmony_ci class A: 9537db96d56Sopenharmony_ci def __getattr__(self, what): 9547db96d56Sopenharmony_ci raise SystemExit 9557db96d56Sopenharmony_ci self.assertRaises(SystemExit, hasattr, A(), "b") 9567db96d56Sopenharmony_ci class B: 9577db96d56Sopenharmony_ci def __getattr__(self, what): 9587db96d56Sopenharmony_ci raise ValueError 9597db96d56Sopenharmony_ci self.assertRaises(ValueError, hasattr, B(), "b") 9607db96d56Sopenharmony_ci 9617db96d56Sopenharmony_ci def test_hash(self): 9627db96d56Sopenharmony_ci hash(None) 9637db96d56Sopenharmony_ci self.assertEqual(hash(1), hash(1)) 9647db96d56Sopenharmony_ci self.assertEqual(hash(1), hash(1.0)) 9657db96d56Sopenharmony_ci hash('spam') 9667db96d56Sopenharmony_ci self.assertEqual(hash('spam'), hash(b'spam')) 9677db96d56Sopenharmony_ci hash((0,1,2,3)) 9687db96d56Sopenharmony_ci def f(): pass 9697db96d56Sopenharmony_ci hash(f) 9707db96d56Sopenharmony_ci self.assertRaises(TypeError, hash, []) 9717db96d56Sopenharmony_ci self.assertRaises(TypeError, hash, {}) 9727db96d56Sopenharmony_ci # Bug 1536021: Allow hash to return long objects 9737db96d56Sopenharmony_ci class X: 9747db96d56Sopenharmony_ci def __hash__(self): 9757db96d56Sopenharmony_ci return 2**100 9767db96d56Sopenharmony_ci self.assertEqual(type(hash(X())), int) 9777db96d56Sopenharmony_ci class Z(int): 9787db96d56Sopenharmony_ci def __hash__(self): 9797db96d56Sopenharmony_ci return self 9807db96d56Sopenharmony_ci self.assertEqual(hash(Z(42)), hash(42)) 9817db96d56Sopenharmony_ci 9827db96d56Sopenharmony_ci def test_hex(self): 9837db96d56Sopenharmony_ci self.assertEqual(hex(16), '0x10') 9847db96d56Sopenharmony_ci self.assertEqual(hex(-16), '-0x10') 9857db96d56Sopenharmony_ci self.assertRaises(TypeError, hex, {}) 9867db96d56Sopenharmony_ci 9877db96d56Sopenharmony_ci def test_id(self): 9887db96d56Sopenharmony_ci id(None) 9897db96d56Sopenharmony_ci id(1) 9907db96d56Sopenharmony_ci id(1.0) 9917db96d56Sopenharmony_ci id('spam') 9927db96d56Sopenharmony_ci id((0,1,2,3)) 9937db96d56Sopenharmony_ci id([0,1,2,3]) 9947db96d56Sopenharmony_ci id({'spam': 1, 'eggs': 2, 'ham': 3}) 9957db96d56Sopenharmony_ci 9967db96d56Sopenharmony_ci # Test input() later, alphabetized as if it were raw_input 9977db96d56Sopenharmony_ci 9987db96d56Sopenharmony_ci def test_iter(self): 9997db96d56Sopenharmony_ci self.assertRaises(TypeError, iter) 10007db96d56Sopenharmony_ci self.assertRaises(TypeError, iter, 42, 42) 10017db96d56Sopenharmony_ci lists = [("1", "2"), ["1", "2"], "12"] 10027db96d56Sopenharmony_ci for l in lists: 10037db96d56Sopenharmony_ci i = iter(l) 10047db96d56Sopenharmony_ci self.assertEqual(next(i), '1') 10057db96d56Sopenharmony_ci self.assertEqual(next(i), '2') 10067db96d56Sopenharmony_ci self.assertRaises(StopIteration, next, i) 10077db96d56Sopenharmony_ci 10087db96d56Sopenharmony_ci def test_isinstance(self): 10097db96d56Sopenharmony_ci class C: 10107db96d56Sopenharmony_ci pass 10117db96d56Sopenharmony_ci class D(C): 10127db96d56Sopenharmony_ci pass 10137db96d56Sopenharmony_ci class E: 10147db96d56Sopenharmony_ci pass 10157db96d56Sopenharmony_ci c = C() 10167db96d56Sopenharmony_ci d = D() 10177db96d56Sopenharmony_ci e = E() 10187db96d56Sopenharmony_ci self.assertTrue(isinstance(c, C)) 10197db96d56Sopenharmony_ci self.assertTrue(isinstance(d, C)) 10207db96d56Sopenharmony_ci self.assertTrue(not isinstance(e, C)) 10217db96d56Sopenharmony_ci self.assertTrue(not isinstance(c, D)) 10227db96d56Sopenharmony_ci self.assertTrue(not isinstance('foo', E)) 10237db96d56Sopenharmony_ci self.assertRaises(TypeError, isinstance, E, 'foo') 10247db96d56Sopenharmony_ci self.assertRaises(TypeError, isinstance) 10257db96d56Sopenharmony_ci 10267db96d56Sopenharmony_ci def test_issubclass(self): 10277db96d56Sopenharmony_ci class C: 10287db96d56Sopenharmony_ci pass 10297db96d56Sopenharmony_ci class D(C): 10307db96d56Sopenharmony_ci pass 10317db96d56Sopenharmony_ci class E: 10327db96d56Sopenharmony_ci pass 10337db96d56Sopenharmony_ci c = C() 10347db96d56Sopenharmony_ci d = D() 10357db96d56Sopenharmony_ci e = E() 10367db96d56Sopenharmony_ci self.assertTrue(issubclass(D, C)) 10377db96d56Sopenharmony_ci self.assertTrue(issubclass(C, C)) 10387db96d56Sopenharmony_ci self.assertTrue(not issubclass(C, D)) 10397db96d56Sopenharmony_ci self.assertRaises(TypeError, issubclass, 'foo', E) 10407db96d56Sopenharmony_ci self.assertRaises(TypeError, issubclass, E, 'foo') 10417db96d56Sopenharmony_ci self.assertRaises(TypeError, issubclass) 10427db96d56Sopenharmony_ci 10437db96d56Sopenharmony_ci def test_len(self): 10447db96d56Sopenharmony_ci self.assertEqual(len('123'), 3) 10457db96d56Sopenharmony_ci self.assertEqual(len(()), 0) 10467db96d56Sopenharmony_ci self.assertEqual(len((1, 2, 3, 4)), 4) 10477db96d56Sopenharmony_ci self.assertEqual(len([1, 2, 3, 4]), 4) 10487db96d56Sopenharmony_ci self.assertEqual(len({}), 0) 10497db96d56Sopenharmony_ci self.assertEqual(len({'a':1, 'b': 2}), 2) 10507db96d56Sopenharmony_ci class BadSeq: 10517db96d56Sopenharmony_ci def __len__(self): 10527db96d56Sopenharmony_ci raise ValueError 10537db96d56Sopenharmony_ci self.assertRaises(ValueError, len, BadSeq()) 10547db96d56Sopenharmony_ci class InvalidLen: 10557db96d56Sopenharmony_ci def __len__(self): 10567db96d56Sopenharmony_ci return None 10577db96d56Sopenharmony_ci self.assertRaises(TypeError, len, InvalidLen()) 10587db96d56Sopenharmony_ci class FloatLen: 10597db96d56Sopenharmony_ci def __len__(self): 10607db96d56Sopenharmony_ci return 4.5 10617db96d56Sopenharmony_ci self.assertRaises(TypeError, len, FloatLen()) 10627db96d56Sopenharmony_ci class NegativeLen: 10637db96d56Sopenharmony_ci def __len__(self): 10647db96d56Sopenharmony_ci return -10 10657db96d56Sopenharmony_ci self.assertRaises(ValueError, len, NegativeLen()) 10667db96d56Sopenharmony_ci class HugeLen: 10677db96d56Sopenharmony_ci def __len__(self): 10687db96d56Sopenharmony_ci return sys.maxsize + 1 10697db96d56Sopenharmony_ci self.assertRaises(OverflowError, len, HugeLen()) 10707db96d56Sopenharmony_ci class HugeNegativeLen: 10717db96d56Sopenharmony_ci def __len__(self): 10727db96d56Sopenharmony_ci return -sys.maxsize-10 10737db96d56Sopenharmony_ci self.assertRaises(ValueError, len, HugeNegativeLen()) 10747db96d56Sopenharmony_ci class NoLenMethod(object): pass 10757db96d56Sopenharmony_ci self.assertRaises(TypeError, len, NoLenMethod()) 10767db96d56Sopenharmony_ci 10777db96d56Sopenharmony_ci def test_map(self): 10787db96d56Sopenharmony_ci self.assertEqual( 10797db96d56Sopenharmony_ci list(map(lambda x: x*x, range(1,4))), 10807db96d56Sopenharmony_ci [1, 4, 9] 10817db96d56Sopenharmony_ci ) 10827db96d56Sopenharmony_ci try: 10837db96d56Sopenharmony_ci from math import sqrt 10847db96d56Sopenharmony_ci except ImportError: 10857db96d56Sopenharmony_ci def sqrt(x): 10867db96d56Sopenharmony_ci return pow(x, 0.5) 10877db96d56Sopenharmony_ci self.assertEqual( 10887db96d56Sopenharmony_ci list(map(lambda x: list(map(sqrt, x)), [[16, 4], [81, 9]])), 10897db96d56Sopenharmony_ci [[4.0, 2.0], [9.0, 3.0]] 10907db96d56Sopenharmony_ci ) 10917db96d56Sopenharmony_ci self.assertEqual( 10927db96d56Sopenharmony_ci list(map(lambda x, y: x+y, [1,3,2], [9,1,4])), 10937db96d56Sopenharmony_ci [10, 4, 6] 10947db96d56Sopenharmony_ci ) 10957db96d56Sopenharmony_ci 10967db96d56Sopenharmony_ci def plus(*v): 10977db96d56Sopenharmony_ci accu = 0 10987db96d56Sopenharmony_ci for i in v: accu = accu + i 10997db96d56Sopenharmony_ci return accu 11007db96d56Sopenharmony_ci self.assertEqual( 11017db96d56Sopenharmony_ci list(map(plus, [1, 3, 7])), 11027db96d56Sopenharmony_ci [1, 3, 7] 11037db96d56Sopenharmony_ci ) 11047db96d56Sopenharmony_ci self.assertEqual( 11057db96d56Sopenharmony_ci list(map(plus, [1, 3, 7], [4, 9, 2])), 11067db96d56Sopenharmony_ci [1+4, 3+9, 7+2] 11077db96d56Sopenharmony_ci ) 11087db96d56Sopenharmony_ci self.assertEqual( 11097db96d56Sopenharmony_ci list(map(plus, [1, 3, 7], [4, 9, 2], [1, 1, 0])), 11107db96d56Sopenharmony_ci [1+4+1, 3+9+1, 7+2+0] 11117db96d56Sopenharmony_ci ) 11127db96d56Sopenharmony_ci self.assertEqual( 11137db96d56Sopenharmony_ci list(map(int, Squares(10))), 11147db96d56Sopenharmony_ci [0, 1, 4, 9, 16, 25, 36, 49, 64, 81] 11157db96d56Sopenharmony_ci ) 11167db96d56Sopenharmony_ci def Max(a, b): 11177db96d56Sopenharmony_ci if a is None: 11187db96d56Sopenharmony_ci return b 11197db96d56Sopenharmony_ci if b is None: 11207db96d56Sopenharmony_ci return a 11217db96d56Sopenharmony_ci return max(a, b) 11227db96d56Sopenharmony_ci self.assertEqual( 11237db96d56Sopenharmony_ci list(map(Max, Squares(3), Squares(2))), 11247db96d56Sopenharmony_ci [0, 1] 11257db96d56Sopenharmony_ci ) 11267db96d56Sopenharmony_ci self.assertRaises(TypeError, map) 11277db96d56Sopenharmony_ci self.assertRaises(TypeError, map, lambda x: x, 42) 11287db96d56Sopenharmony_ci class BadSeq: 11297db96d56Sopenharmony_ci def __iter__(self): 11307db96d56Sopenharmony_ci raise ValueError 11317db96d56Sopenharmony_ci yield None 11327db96d56Sopenharmony_ci self.assertRaises(ValueError, list, map(lambda x: x, BadSeq())) 11337db96d56Sopenharmony_ci def badfunc(x): 11347db96d56Sopenharmony_ci raise RuntimeError 11357db96d56Sopenharmony_ci self.assertRaises(RuntimeError, list, map(badfunc, range(5))) 11367db96d56Sopenharmony_ci 11377db96d56Sopenharmony_ci def test_map_pickle(self): 11387db96d56Sopenharmony_ci for proto in range(pickle.HIGHEST_PROTOCOL + 1): 11397db96d56Sopenharmony_ci m1 = map(map_char, "Is this the real life?") 11407db96d56Sopenharmony_ci m2 = map(map_char, "Is this the real life?") 11417db96d56Sopenharmony_ci self.check_iter_pickle(m1, list(m2), proto) 11427db96d56Sopenharmony_ci 11437db96d56Sopenharmony_ci def test_max(self): 11447db96d56Sopenharmony_ci self.assertEqual(max('123123'), '3') 11457db96d56Sopenharmony_ci self.assertEqual(max(1, 2, 3), 3) 11467db96d56Sopenharmony_ci self.assertEqual(max((1, 2, 3, 1, 2, 3)), 3) 11477db96d56Sopenharmony_ci self.assertEqual(max([1, 2, 3, 1, 2, 3]), 3) 11487db96d56Sopenharmony_ci 11497db96d56Sopenharmony_ci self.assertEqual(max(1, 2, 3.0), 3.0) 11507db96d56Sopenharmony_ci self.assertEqual(max(1, 2.0, 3), 3) 11517db96d56Sopenharmony_ci self.assertEqual(max(1.0, 2, 3), 3) 11527db96d56Sopenharmony_ci 11537db96d56Sopenharmony_ci with self.assertRaisesRegex( 11547db96d56Sopenharmony_ci TypeError, 11557db96d56Sopenharmony_ci 'max expected at least 1 argument, got 0' 11567db96d56Sopenharmony_ci ): 11577db96d56Sopenharmony_ci max() 11587db96d56Sopenharmony_ci 11597db96d56Sopenharmony_ci self.assertRaises(TypeError, max, 42) 11607db96d56Sopenharmony_ci self.assertRaises(ValueError, max, ()) 11617db96d56Sopenharmony_ci class BadSeq: 11627db96d56Sopenharmony_ci def __getitem__(self, index): 11637db96d56Sopenharmony_ci raise ValueError 11647db96d56Sopenharmony_ci self.assertRaises(ValueError, max, BadSeq()) 11657db96d56Sopenharmony_ci 11667db96d56Sopenharmony_ci for stmt in ( 11677db96d56Sopenharmony_ci "max(key=int)", # no args 11687db96d56Sopenharmony_ci "max(default=None)", 11697db96d56Sopenharmony_ci "max(1, 2, default=None)", # require container for default 11707db96d56Sopenharmony_ci "max(default=None, key=int)", 11717db96d56Sopenharmony_ci "max(1, key=int)", # single arg not iterable 11727db96d56Sopenharmony_ci "max(1, 2, keystone=int)", # wrong keyword 11737db96d56Sopenharmony_ci "max(1, 2, key=int, abc=int)", # two many keywords 11747db96d56Sopenharmony_ci "max(1, 2, key=1)", # keyfunc is not callable 11757db96d56Sopenharmony_ci ): 11767db96d56Sopenharmony_ci try: 11777db96d56Sopenharmony_ci exec(stmt, globals()) 11787db96d56Sopenharmony_ci except TypeError: 11797db96d56Sopenharmony_ci pass 11807db96d56Sopenharmony_ci else: 11817db96d56Sopenharmony_ci self.fail(stmt) 11827db96d56Sopenharmony_ci 11837db96d56Sopenharmony_ci self.assertEqual(max((1,), key=neg), 1) # one elem iterable 11847db96d56Sopenharmony_ci self.assertEqual(max((1,2), key=neg), 1) # two elem iterable 11857db96d56Sopenharmony_ci self.assertEqual(max(1, 2, key=neg), 1) # two elems 11867db96d56Sopenharmony_ci 11877db96d56Sopenharmony_ci self.assertEqual(max((), default=None), None) # zero elem iterable 11887db96d56Sopenharmony_ci self.assertEqual(max((1,), default=None), 1) # one elem iterable 11897db96d56Sopenharmony_ci self.assertEqual(max((1,2), default=None), 2) # two elem iterable 11907db96d56Sopenharmony_ci 11917db96d56Sopenharmony_ci self.assertEqual(max((), default=1, key=neg), 1) 11927db96d56Sopenharmony_ci self.assertEqual(max((1, 2), default=3, key=neg), 1) 11937db96d56Sopenharmony_ci 11947db96d56Sopenharmony_ci self.assertEqual(max((1, 2), key=None), 2) 11957db96d56Sopenharmony_ci 11967db96d56Sopenharmony_ci data = [random.randrange(200) for i in range(100)] 11977db96d56Sopenharmony_ci keys = dict((elem, random.randrange(50)) for elem in data) 11987db96d56Sopenharmony_ci f = keys.__getitem__ 11997db96d56Sopenharmony_ci self.assertEqual(max(data, key=f), 12007db96d56Sopenharmony_ci sorted(reversed(data), key=f)[-1]) 12017db96d56Sopenharmony_ci 12027db96d56Sopenharmony_ci def test_min(self): 12037db96d56Sopenharmony_ci self.assertEqual(min('123123'), '1') 12047db96d56Sopenharmony_ci self.assertEqual(min(1, 2, 3), 1) 12057db96d56Sopenharmony_ci self.assertEqual(min((1, 2, 3, 1, 2, 3)), 1) 12067db96d56Sopenharmony_ci self.assertEqual(min([1, 2, 3, 1, 2, 3]), 1) 12077db96d56Sopenharmony_ci 12087db96d56Sopenharmony_ci self.assertEqual(min(1, 2, 3.0), 1) 12097db96d56Sopenharmony_ci self.assertEqual(min(1, 2.0, 3), 1) 12107db96d56Sopenharmony_ci self.assertEqual(min(1.0, 2, 3), 1.0) 12117db96d56Sopenharmony_ci 12127db96d56Sopenharmony_ci with self.assertRaisesRegex( 12137db96d56Sopenharmony_ci TypeError, 12147db96d56Sopenharmony_ci 'min expected at least 1 argument, got 0' 12157db96d56Sopenharmony_ci ): 12167db96d56Sopenharmony_ci min() 12177db96d56Sopenharmony_ci 12187db96d56Sopenharmony_ci self.assertRaises(TypeError, min, 42) 12197db96d56Sopenharmony_ci self.assertRaises(ValueError, min, ()) 12207db96d56Sopenharmony_ci class BadSeq: 12217db96d56Sopenharmony_ci def __getitem__(self, index): 12227db96d56Sopenharmony_ci raise ValueError 12237db96d56Sopenharmony_ci self.assertRaises(ValueError, min, BadSeq()) 12247db96d56Sopenharmony_ci 12257db96d56Sopenharmony_ci for stmt in ( 12267db96d56Sopenharmony_ci "min(key=int)", # no args 12277db96d56Sopenharmony_ci "min(default=None)", 12287db96d56Sopenharmony_ci "min(1, 2, default=None)", # require container for default 12297db96d56Sopenharmony_ci "min(default=None, key=int)", 12307db96d56Sopenharmony_ci "min(1, key=int)", # single arg not iterable 12317db96d56Sopenharmony_ci "min(1, 2, keystone=int)", # wrong keyword 12327db96d56Sopenharmony_ci "min(1, 2, key=int, abc=int)", # two many keywords 12337db96d56Sopenharmony_ci "min(1, 2, key=1)", # keyfunc is not callable 12347db96d56Sopenharmony_ci ): 12357db96d56Sopenharmony_ci try: 12367db96d56Sopenharmony_ci exec(stmt, globals()) 12377db96d56Sopenharmony_ci except TypeError: 12387db96d56Sopenharmony_ci pass 12397db96d56Sopenharmony_ci else: 12407db96d56Sopenharmony_ci self.fail(stmt) 12417db96d56Sopenharmony_ci 12427db96d56Sopenharmony_ci self.assertEqual(min((1,), key=neg), 1) # one elem iterable 12437db96d56Sopenharmony_ci self.assertEqual(min((1,2), key=neg), 2) # two elem iterable 12447db96d56Sopenharmony_ci self.assertEqual(min(1, 2, key=neg), 2) # two elems 12457db96d56Sopenharmony_ci 12467db96d56Sopenharmony_ci self.assertEqual(min((), default=None), None) # zero elem iterable 12477db96d56Sopenharmony_ci self.assertEqual(min((1,), default=None), 1) # one elem iterable 12487db96d56Sopenharmony_ci self.assertEqual(min((1,2), default=None), 1) # two elem iterable 12497db96d56Sopenharmony_ci 12507db96d56Sopenharmony_ci self.assertEqual(min((), default=1, key=neg), 1) 12517db96d56Sopenharmony_ci self.assertEqual(min((1, 2), default=1, key=neg), 2) 12527db96d56Sopenharmony_ci 12537db96d56Sopenharmony_ci self.assertEqual(min((1, 2), key=None), 1) 12547db96d56Sopenharmony_ci 12557db96d56Sopenharmony_ci data = [random.randrange(200) for i in range(100)] 12567db96d56Sopenharmony_ci keys = dict((elem, random.randrange(50)) for elem in data) 12577db96d56Sopenharmony_ci f = keys.__getitem__ 12587db96d56Sopenharmony_ci self.assertEqual(min(data, key=f), 12597db96d56Sopenharmony_ci sorted(data, key=f)[0]) 12607db96d56Sopenharmony_ci 12617db96d56Sopenharmony_ci def test_next(self): 12627db96d56Sopenharmony_ci it = iter(range(2)) 12637db96d56Sopenharmony_ci self.assertEqual(next(it), 0) 12647db96d56Sopenharmony_ci self.assertEqual(next(it), 1) 12657db96d56Sopenharmony_ci self.assertRaises(StopIteration, next, it) 12667db96d56Sopenharmony_ci self.assertRaises(StopIteration, next, it) 12677db96d56Sopenharmony_ci self.assertEqual(next(it, 42), 42) 12687db96d56Sopenharmony_ci 12697db96d56Sopenharmony_ci class Iter(object): 12707db96d56Sopenharmony_ci def __iter__(self): 12717db96d56Sopenharmony_ci return self 12727db96d56Sopenharmony_ci def __next__(self): 12737db96d56Sopenharmony_ci raise StopIteration 12747db96d56Sopenharmony_ci 12757db96d56Sopenharmony_ci it = iter(Iter()) 12767db96d56Sopenharmony_ci self.assertEqual(next(it, 42), 42) 12777db96d56Sopenharmony_ci self.assertRaises(StopIteration, next, it) 12787db96d56Sopenharmony_ci 12797db96d56Sopenharmony_ci def gen(): 12807db96d56Sopenharmony_ci yield 1 12817db96d56Sopenharmony_ci return 12827db96d56Sopenharmony_ci 12837db96d56Sopenharmony_ci it = gen() 12847db96d56Sopenharmony_ci self.assertEqual(next(it), 1) 12857db96d56Sopenharmony_ci self.assertRaises(StopIteration, next, it) 12867db96d56Sopenharmony_ci self.assertEqual(next(it, 42), 42) 12877db96d56Sopenharmony_ci 12887db96d56Sopenharmony_ci def test_oct(self): 12897db96d56Sopenharmony_ci self.assertEqual(oct(100), '0o144') 12907db96d56Sopenharmony_ci self.assertEqual(oct(-100), '-0o144') 12917db96d56Sopenharmony_ci self.assertRaises(TypeError, oct, ()) 12927db96d56Sopenharmony_ci 12937db96d56Sopenharmony_ci def write_testfile(self): 12947db96d56Sopenharmony_ci # NB the first 4 lines are also used to test input, below 12957db96d56Sopenharmony_ci fp = open(TESTFN, 'w', encoding="utf-8") 12967db96d56Sopenharmony_ci self.addCleanup(unlink, TESTFN) 12977db96d56Sopenharmony_ci with fp: 12987db96d56Sopenharmony_ci fp.write('1+1\n') 12997db96d56Sopenharmony_ci fp.write('The quick brown fox jumps over the lazy dog') 13007db96d56Sopenharmony_ci fp.write('.\n') 13017db96d56Sopenharmony_ci fp.write('Dear John\n') 13027db96d56Sopenharmony_ci fp.write('XXX'*100) 13037db96d56Sopenharmony_ci fp.write('YYY'*100) 13047db96d56Sopenharmony_ci 13057db96d56Sopenharmony_ci def test_open(self): 13067db96d56Sopenharmony_ci self.write_testfile() 13077db96d56Sopenharmony_ci fp = open(TESTFN, encoding="utf-8") 13087db96d56Sopenharmony_ci with fp: 13097db96d56Sopenharmony_ci self.assertEqual(fp.readline(4), '1+1\n') 13107db96d56Sopenharmony_ci self.assertEqual(fp.readline(), 'The quick brown fox jumps over the lazy dog.\n') 13117db96d56Sopenharmony_ci self.assertEqual(fp.readline(4), 'Dear') 13127db96d56Sopenharmony_ci self.assertEqual(fp.readline(100), ' John\n') 13137db96d56Sopenharmony_ci self.assertEqual(fp.read(300), 'XXX'*100) 13147db96d56Sopenharmony_ci self.assertEqual(fp.read(1000), 'YYY'*100) 13157db96d56Sopenharmony_ci 13167db96d56Sopenharmony_ci # embedded null bytes and characters 13177db96d56Sopenharmony_ci self.assertRaises(ValueError, open, 'a\x00b') 13187db96d56Sopenharmony_ci self.assertRaises(ValueError, open, b'a\x00b') 13197db96d56Sopenharmony_ci 13207db96d56Sopenharmony_ci @unittest.skipIf(sys.flags.utf8_mode, "utf-8 mode is enabled") 13217db96d56Sopenharmony_ci def test_open_default_encoding(self): 13227db96d56Sopenharmony_ci old_environ = dict(os.environ) 13237db96d56Sopenharmony_ci try: 13247db96d56Sopenharmony_ci # try to get a user preferred encoding different than the current 13257db96d56Sopenharmony_ci # locale encoding to check that open() uses the current locale 13267db96d56Sopenharmony_ci # encoding and not the user preferred encoding 13277db96d56Sopenharmony_ci for key in ('LC_ALL', 'LANG', 'LC_CTYPE'): 13287db96d56Sopenharmony_ci if key in os.environ: 13297db96d56Sopenharmony_ci del os.environ[key] 13307db96d56Sopenharmony_ci 13317db96d56Sopenharmony_ci self.write_testfile() 13327db96d56Sopenharmony_ci current_locale_encoding = locale.getencoding() 13337db96d56Sopenharmony_ci with warnings.catch_warnings(): 13347db96d56Sopenharmony_ci warnings.simplefilter("ignore", EncodingWarning) 13357db96d56Sopenharmony_ci fp = open(TESTFN, 'w') 13367db96d56Sopenharmony_ci with fp: 13377db96d56Sopenharmony_ci self.assertEqual(fp.encoding, current_locale_encoding) 13387db96d56Sopenharmony_ci finally: 13397db96d56Sopenharmony_ci os.environ.clear() 13407db96d56Sopenharmony_ci os.environ.update(old_environ) 13417db96d56Sopenharmony_ci 13427db96d56Sopenharmony_ci @support.requires_subprocess() 13437db96d56Sopenharmony_ci def test_open_non_inheritable(self): 13447db96d56Sopenharmony_ci fileobj = open(__file__, encoding="utf-8") 13457db96d56Sopenharmony_ci with fileobj: 13467db96d56Sopenharmony_ci self.assertFalse(os.get_inheritable(fileobj.fileno())) 13477db96d56Sopenharmony_ci 13487db96d56Sopenharmony_ci def test_ord(self): 13497db96d56Sopenharmony_ci self.assertEqual(ord(' '), 32) 13507db96d56Sopenharmony_ci self.assertEqual(ord('A'), 65) 13517db96d56Sopenharmony_ci self.assertEqual(ord('a'), 97) 13527db96d56Sopenharmony_ci self.assertEqual(ord('\x80'), 128) 13537db96d56Sopenharmony_ci self.assertEqual(ord('\xff'), 255) 13547db96d56Sopenharmony_ci 13557db96d56Sopenharmony_ci self.assertEqual(ord(b' '), 32) 13567db96d56Sopenharmony_ci self.assertEqual(ord(b'A'), 65) 13577db96d56Sopenharmony_ci self.assertEqual(ord(b'a'), 97) 13587db96d56Sopenharmony_ci self.assertEqual(ord(b'\x80'), 128) 13597db96d56Sopenharmony_ci self.assertEqual(ord(b'\xff'), 255) 13607db96d56Sopenharmony_ci 13617db96d56Sopenharmony_ci self.assertEqual(ord(chr(sys.maxunicode)), sys.maxunicode) 13627db96d56Sopenharmony_ci self.assertRaises(TypeError, ord, 42) 13637db96d56Sopenharmony_ci 13647db96d56Sopenharmony_ci self.assertEqual(ord(chr(0x10FFFF)), 0x10FFFF) 13657db96d56Sopenharmony_ci self.assertEqual(ord("\U0000FFFF"), 0x0000FFFF) 13667db96d56Sopenharmony_ci self.assertEqual(ord("\U00010000"), 0x00010000) 13677db96d56Sopenharmony_ci self.assertEqual(ord("\U00010001"), 0x00010001) 13687db96d56Sopenharmony_ci self.assertEqual(ord("\U000FFFFE"), 0x000FFFFE) 13697db96d56Sopenharmony_ci self.assertEqual(ord("\U000FFFFF"), 0x000FFFFF) 13707db96d56Sopenharmony_ci self.assertEqual(ord("\U00100000"), 0x00100000) 13717db96d56Sopenharmony_ci self.assertEqual(ord("\U00100001"), 0x00100001) 13727db96d56Sopenharmony_ci self.assertEqual(ord("\U0010FFFE"), 0x0010FFFE) 13737db96d56Sopenharmony_ci self.assertEqual(ord("\U0010FFFF"), 0x0010FFFF) 13747db96d56Sopenharmony_ci 13757db96d56Sopenharmony_ci def test_pow(self): 13767db96d56Sopenharmony_ci self.assertEqual(pow(0,0), 1) 13777db96d56Sopenharmony_ci self.assertEqual(pow(0,1), 0) 13787db96d56Sopenharmony_ci self.assertEqual(pow(1,0), 1) 13797db96d56Sopenharmony_ci self.assertEqual(pow(1,1), 1) 13807db96d56Sopenharmony_ci 13817db96d56Sopenharmony_ci self.assertEqual(pow(2,0), 1) 13827db96d56Sopenharmony_ci self.assertEqual(pow(2,10), 1024) 13837db96d56Sopenharmony_ci self.assertEqual(pow(2,20), 1024*1024) 13847db96d56Sopenharmony_ci self.assertEqual(pow(2,30), 1024*1024*1024) 13857db96d56Sopenharmony_ci 13867db96d56Sopenharmony_ci self.assertEqual(pow(-2,0), 1) 13877db96d56Sopenharmony_ci self.assertEqual(pow(-2,1), -2) 13887db96d56Sopenharmony_ci self.assertEqual(pow(-2,2), 4) 13897db96d56Sopenharmony_ci self.assertEqual(pow(-2,3), -8) 13907db96d56Sopenharmony_ci 13917db96d56Sopenharmony_ci self.assertAlmostEqual(pow(0.,0), 1.) 13927db96d56Sopenharmony_ci self.assertAlmostEqual(pow(0.,1), 0.) 13937db96d56Sopenharmony_ci self.assertAlmostEqual(pow(1.,0), 1.) 13947db96d56Sopenharmony_ci self.assertAlmostEqual(pow(1.,1), 1.) 13957db96d56Sopenharmony_ci 13967db96d56Sopenharmony_ci self.assertAlmostEqual(pow(2.,0), 1.) 13977db96d56Sopenharmony_ci self.assertAlmostEqual(pow(2.,10), 1024.) 13987db96d56Sopenharmony_ci self.assertAlmostEqual(pow(2.,20), 1024.*1024.) 13997db96d56Sopenharmony_ci self.assertAlmostEqual(pow(2.,30), 1024.*1024.*1024.) 14007db96d56Sopenharmony_ci 14017db96d56Sopenharmony_ci self.assertAlmostEqual(pow(-2.,0), 1.) 14027db96d56Sopenharmony_ci self.assertAlmostEqual(pow(-2.,1), -2.) 14037db96d56Sopenharmony_ci self.assertAlmostEqual(pow(-2.,2), 4.) 14047db96d56Sopenharmony_ci self.assertAlmostEqual(pow(-2.,3), -8.) 14057db96d56Sopenharmony_ci 14067db96d56Sopenharmony_ci for x in 2, 2.0: 14077db96d56Sopenharmony_ci for y in 10, 10.0: 14087db96d56Sopenharmony_ci for z in 1000, 1000.0: 14097db96d56Sopenharmony_ci if isinstance(x, float) or \ 14107db96d56Sopenharmony_ci isinstance(y, float) or \ 14117db96d56Sopenharmony_ci isinstance(z, float): 14127db96d56Sopenharmony_ci self.assertRaises(TypeError, pow, x, y, z) 14137db96d56Sopenharmony_ci else: 14147db96d56Sopenharmony_ci self.assertAlmostEqual(pow(x, y, z), 24.0) 14157db96d56Sopenharmony_ci 14167db96d56Sopenharmony_ci self.assertAlmostEqual(pow(-1, 0.5), 1j) 14177db96d56Sopenharmony_ci self.assertAlmostEqual(pow(-1, 1/3), 0.5 + 0.8660254037844386j) 14187db96d56Sopenharmony_ci 14197db96d56Sopenharmony_ci # See test_pow for additional tests for three-argument pow. 14207db96d56Sopenharmony_ci self.assertEqual(pow(-1, -2, 3), 1) 14217db96d56Sopenharmony_ci self.assertRaises(ValueError, pow, 1, 2, 0) 14227db96d56Sopenharmony_ci 14237db96d56Sopenharmony_ci self.assertRaises(TypeError, pow) 14247db96d56Sopenharmony_ci 14257db96d56Sopenharmony_ci # Test passing in arguments as keywords. 14267db96d56Sopenharmony_ci self.assertEqual(pow(0, exp=0), 1) 14277db96d56Sopenharmony_ci self.assertEqual(pow(base=2, exp=4), 16) 14287db96d56Sopenharmony_ci self.assertEqual(pow(base=5, exp=2, mod=14), 11) 14297db96d56Sopenharmony_ci twopow = partial(pow, base=2) 14307db96d56Sopenharmony_ci self.assertEqual(twopow(exp=5), 32) 14317db96d56Sopenharmony_ci fifth_power = partial(pow, exp=5) 14327db96d56Sopenharmony_ci self.assertEqual(fifth_power(2), 32) 14337db96d56Sopenharmony_ci mod10 = partial(pow, mod=10) 14347db96d56Sopenharmony_ci self.assertEqual(mod10(2, 6), 4) 14357db96d56Sopenharmony_ci self.assertEqual(mod10(exp=6, base=2), 4) 14367db96d56Sopenharmony_ci 14377db96d56Sopenharmony_ci def test_input(self): 14387db96d56Sopenharmony_ci self.write_testfile() 14397db96d56Sopenharmony_ci fp = open(TESTFN, encoding="utf-8") 14407db96d56Sopenharmony_ci savestdin = sys.stdin 14417db96d56Sopenharmony_ci savestdout = sys.stdout # Eats the echo 14427db96d56Sopenharmony_ci try: 14437db96d56Sopenharmony_ci sys.stdin = fp 14447db96d56Sopenharmony_ci sys.stdout = BitBucket() 14457db96d56Sopenharmony_ci self.assertEqual(input(), "1+1") 14467db96d56Sopenharmony_ci self.assertEqual(input(), 'The quick brown fox jumps over the lazy dog.') 14477db96d56Sopenharmony_ci self.assertEqual(input('testing\n'), 'Dear John') 14487db96d56Sopenharmony_ci 14497db96d56Sopenharmony_ci # SF 1535165: don't segfault on closed stdin 14507db96d56Sopenharmony_ci # sys.stdout must be a regular file for triggering 14517db96d56Sopenharmony_ci sys.stdout = savestdout 14527db96d56Sopenharmony_ci sys.stdin.close() 14537db96d56Sopenharmony_ci self.assertRaises(ValueError, input) 14547db96d56Sopenharmony_ci 14557db96d56Sopenharmony_ci sys.stdout = BitBucket() 14567db96d56Sopenharmony_ci sys.stdin = io.StringIO("NULL\0") 14577db96d56Sopenharmony_ci self.assertRaises(TypeError, input, 42, 42) 14587db96d56Sopenharmony_ci sys.stdin = io.StringIO(" 'whitespace'") 14597db96d56Sopenharmony_ci self.assertEqual(input(), " 'whitespace'") 14607db96d56Sopenharmony_ci sys.stdin = io.StringIO() 14617db96d56Sopenharmony_ci self.assertRaises(EOFError, input) 14627db96d56Sopenharmony_ci 14637db96d56Sopenharmony_ci del sys.stdout 14647db96d56Sopenharmony_ci self.assertRaises(RuntimeError, input, 'prompt') 14657db96d56Sopenharmony_ci del sys.stdin 14667db96d56Sopenharmony_ci self.assertRaises(RuntimeError, input, 'prompt') 14677db96d56Sopenharmony_ci finally: 14687db96d56Sopenharmony_ci sys.stdin = savestdin 14697db96d56Sopenharmony_ci sys.stdout = savestdout 14707db96d56Sopenharmony_ci fp.close() 14717db96d56Sopenharmony_ci 14727db96d56Sopenharmony_ci # test_int(): see test_int.py for tests of built-in function int(). 14737db96d56Sopenharmony_ci 14747db96d56Sopenharmony_ci def test_repr(self): 14757db96d56Sopenharmony_ci self.assertEqual(repr(''), '\'\'') 14767db96d56Sopenharmony_ci self.assertEqual(repr(0), '0') 14777db96d56Sopenharmony_ci self.assertEqual(repr(()), '()') 14787db96d56Sopenharmony_ci self.assertEqual(repr([]), '[]') 14797db96d56Sopenharmony_ci self.assertEqual(repr({}), '{}') 14807db96d56Sopenharmony_ci a = [] 14817db96d56Sopenharmony_ci a.append(a) 14827db96d56Sopenharmony_ci self.assertEqual(repr(a), '[[...]]') 14837db96d56Sopenharmony_ci a = {} 14847db96d56Sopenharmony_ci a[0] = a 14857db96d56Sopenharmony_ci self.assertEqual(repr(a), '{0: {...}}') 14867db96d56Sopenharmony_ci 14877db96d56Sopenharmony_ci def test_round(self): 14887db96d56Sopenharmony_ci self.assertEqual(round(0.0), 0.0) 14897db96d56Sopenharmony_ci self.assertEqual(type(round(0.0)), int) 14907db96d56Sopenharmony_ci self.assertEqual(round(1.0), 1.0) 14917db96d56Sopenharmony_ci self.assertEqual(round(10.0), 10.0) 14927db96d56Sopenharmony_ci self.assertEqual(round(1000000000.0), 1000000000.0) 14937db96d56Sopenharmony_ci self.assertEqual(round(1e20), 1e20) 14947db96d56Sopenharmony_ci 14957db96d56Sopenharmony_ci self.assertEqual(round(-1.0), -1.0) 14967db96d56Sopenharmony_ci self.assertEqual(round(-10.0), -10.0) 14977db96d56Sopenharmony_ci self.assertEqual(round(-1000000000.0), -1000000000.0) 14987db96d56Sopenharmony_ci self.assertEqual(round(-1e20), -1e20) 14997db96d56Sopenharmony_ci 15007db96d56Sopenharmony_ci self.assertEqual(round(0.1), 0.0) 15017db96d56Sopenharmony_ci self.assertEqual(round(1.1), 1.0) 15027db96d56Sopenharmony_ci self.assertEqual(round(10.1), 10.0) 15037db96d56Sopenharmony_ci self.assertEqual(round(1000000000.1), 1000000000.0) 15047db96d56Sopenharmony_ci 15057db96d56Sopenharmony_ci self.assertEqual(round(-1.1), -1.0) 15067db96d56Sopenharmony_ci self.assertEqual(round(-10.1), -10.0) 15077db96d56Sopenharmony_ci self.assertEqual(round(-1000000000.1), -1000000000.0) 15087db96d56Sopenharmony_ci 15097db96d56Sopenharmony_ci self.assertEqual(round(0.9), 1.0) 15107db96d56Sopenharmony_ci self.assertEqual(round(9.9), 10.0) 15117db96d56Sopenharmony_ci self.assertEqual(round(999999999.9), 1000000000.0) 15127db96d56Sopenharmony_ci 15137db96d56Sopenharmony_ci self.assertEqual(round(-0.9), -1.0) 15147db96d56Sopenharmony_ci self.assertEqual(round(-9.9), -10.0) 15157db96d56Sopenharmony_ci self.assertEqual(round(-999999999.9), -1000000000.0) 15167db96d56Sopenharmony_ci 15177db96d56Sopenharmony_ci self.assertEqual(round(-8.0, -1), -10.0) 15187db96d56Sopenharmony_ci self.assertEqual(type(round(-8.0, -1)), float) 15197db96d56Sopenharmony_ci 15207db96d56Sopenharmony_ci self.assertEqual(type(round(-8.0, 0)), float) 15217db96d56Sopenharmony_ci self.assertEqual(type(round(-8.0, 1)), float) 15227db96d56Sopenharmony_ci 15237db96d56Sopenharmony_ci # Check even / odd rounding behaviour 15247db96d56Sopenharmony_ci self.assertEqual(round(5.5), 6) 15257db96d56Sopenharmony_ci self.assertEqual(round(6.5), 6) 15267db96d56Sopenharmony_ci self.assertEqual(round(-5.5), -6) 15277db96d56Sopenharmony_ci self.assertEqual(round(-6.5), -6) 15287db96d56Sopenharmony_ci 15297db96d56Sopenharmony_ci # Check behavior on ints 15307db96d56Sopenharmony_ci self.assertEqual(round(0), 0) 15317db96d56Sopenharmony_ci self.assertEqual(round(8), 8) 15327db96d56Sopenharmony_ci self.assertEqual(round(-8), -8) 15337db96d56Sopenharmony_ci self.assertEqual(type(round(0)), int) 15347db96d56Sopenharmony_ci self.assertEqual(type(round(-8, -1)), int) 15357db96d56Sopenharmony_ci self.assertEqual(type(round(-8, 0)), int) 15367db96d56Sopenharmony_ci self.assertEqual(type(round(-8, 1)), int) 15377db96d56Sopenharmony_ci 15387db96d56Sopenharmony_ci # test new kwargs 15397db96d56Sopenharmony_ci self.assertEqual(round(number=-8.0, ndigits=-1), -10.0) 15407db96d56Sopenharmony_ci 15417db96d56Sopenharmony_ci self.assertRaises(TypeError, round) 15427db96d56Sopenharmony_ci 15437db96d56Sopenharmony_ci # test generic rounding delegation for reals 15447db96d56Sopenharmony_ci class TestRound: 15457db96d56Sopenharmony_ci def __round__(self): 15467db96d56Sopenharmony_ci return 23 15477db96d56Sopenharmony_ci 15487db96d56Sopenharmony_ci class TestNoRound: 15497db96d56Sopenharmony_ci pass 15507db96d56Sopenharmony_ci 15517db96d56Sopenharmony_ci self.assertEqual(round(TestRound()), 23) 15527db96d56Sopenharmony_ci 15537db96d56Sopenharmony_ci self.assertRaises(TypeError, round, 1, 2, 3) 15547db96d56Sopenharmony_ci self.assertRaises(TypeError, round, TestNoRound()) 15557db96d56Sopenharmony_ci 15567db96d56Sopenharmony_ci t = TestNoRound() 15577db96d56Sopenharmony_ci t.__round__ = lambda *args: args 15587db96d56Sopenharmony_ci self.assertRaises(TypeError, round, t) 15597db96d56Sopenharmony_ci self.assertRaises(TypeError, round, t, 0) 15607db96d56Sopenharmony_ci 15617db96d56Sopenharmony_ci # Some versions of glibc for alpha have a bug that affects 15627db96d56Sopenharmony_ci # float -> integer rounding (floor, ceil, rint, round) for 15637db96d56Sopenharmony_ci # values in the range [2**52, 2**53). See: 15647db96d56Sopenharmony_ci # 15657db96d56Sopenharmony_ci # http://sources.redhat.com/bugzilla/show_bug.cgi?id=5350 15667db96d56Sopenharmony_ci # 15677db96d56Sopenharmony_ci # We skip this test on Linux/alpha if it would fail. 15687db96d56Sopenharmony_ci linux_alpha = (platform.system().startswith('Linux') and 15697db96d56Sopenharmony_ci platform.machine().startswith('alpha')) 15707db96d56Sopenharmony_ci system_round_bug = round(5e15+1) != 5e15+1 15717db96d56Sopenharmony_ci @unittest.skipIf(linux_alpha and system_round_bug, 15727db96d56Sopenharmony_ci "test will fail; failure is probably due to a " 15737db96d56Sopenharmony_ci "buggy system round function") 15747db96d56Sopenharmony_ci def test_round_large(self): 15757db96d56Sopenharmony_ci # Issue #1869: integral floats should remain unchanged 15767db96d56Sopenharmony_ci self.assertEqual(round(5e15-1), 5e15-1) 15777db96d56Sopenharmony_ci self.assertEqual(round(5e15), 5e15) 15787db96d56Sopenharmony_ci self.assertEqual(round(5e15+1), 5e15+1) 15797db96d56Sopenharmony_ci self.assertEqual(round(5e15+2), 5e15+2) 15807db96d56Sopenharmony_ci self.assertEqual(round(5e15+3), 5e15+3) 15817db96d56Sopenharmony_ci 15827db96d56Sopenharmony_ci def test_bug_27936(self): 15837db96d56Sopenharmony_ci # Verify that ndigits=None means the same as passing in no argument 15847db96d56Sopenharmony_ci for x in [1234, 15857db96d56Sopenharmony_ci 1234.56, 15867db96d56Sopenharmony_ci decimal.Decimal('1234.56'), 15877db96d56Sopenharmony_ci fractions.Fraction(123456, 100)]: 15887db96d56Sopenharmony_ci self.assertEqual(round(x, None), round(x)) 15897db96d56Sopenharmony_ci self.assertEqual(type(round(x, None)), type(round(x))) 15907db96d56Sopenharmony_ci 15917db96d56Sopenharmony_ci def test_setattr(self): 15927db96d56Sopenharmony_ci setattr(sys, 'spam', 1) 15937db96d56Sopenharmony_ci self.assertEqual(sys.spam, 1) 15947db96d56Sopenharmony_ci self.assertRaises(TypeError, setattr) 15957db96d56Sopenharmony_ci self.assertRaises(TypeError, setattr, sys) 15967db96d56Sopenharmony_ci self.assertRaises(TypeError, setattr, sys, 'spam') 15977db96d56Sopenharmony_ci msg = r"^attribute name must be string, not 'int'$" 15987db96d56Sopenharmony_ci self.assertRaisesRegex(TypeError, msg, setattr, sys, 1, 'spam') 15997db96d56Sopenharmony_ci 16007db96d56Sopenharmony_ci # test_str(): see test_unicode.py and test_bytes.py for str() tests. 16017db96d56Sopenharmony_ci 16027db96d56Sopenharmony_ci def test_sum(self): 16037db96d56Sopenharmony_ci self.assertEqual(sum([]), 0) 16047db96d56Sopenharmony_ci self.assertEqual(sum(list(range(2,8))), 27) 16057db96d56Sopenharmony_ci self.assertEqual(sum(iter(list(range(2,8)))), 27) 16067db96d56Sopenharmony_ci self.assertEqual(sum(Squares(10)), 285) 16077db96d56Sopenharmony_ci self.assertEqual(sum(iter(Squares(10))), 285) 16087db96d56Sopenharmony_ci self.assertEqual(sum([[1], [2], [3]], []), [1, 2, 3]) 16097db96d56Sopenharmony_ci 16107db96d56Sopenharmony_ci self.assertEqual(sum(range(10), 1000), 1045) 16117db96d56Sopenharmony_ci self.assertEqual(sum(range(10), start=1000), 1045) 16127db96d56Sopenharmony_ci self.assertEqual(sum(range(10), 2**31-5), 2**31+40) 16137db96d56Sopenharmony_ci self.assertEqual(sum(range(10), 2**63-5), 2**63+40) 16147db96d56Sopenharmony_ci 16157db96d56Sopenharmony_ci self.assertEqual(sum(i % 2 != 0 for i in range(10)), 5) 16167db96d56Sopenharmony_ci self.assertEqual(sum((i % 2 != 0 for i in range(10)), 2**31-3), 16177db96d56Sopenharmony_ci 2**31+2) 16187db96d56Sopenharmony_ci self.assertEqual(sum((i % 2 != 0 for i in range(10)), 2**63-3), 16197db96d56Sopenharmony_ci 2**63+2) 16207db96d56Sopenharmony_ci self.assertIs(sum([], False), False) 16217db96d56Sopenharmony_ci 16227db96d56Sopenharmony_ci self.assertEqual(sum(i / 2 for i in range(10)), 22.5) 16237db96d56Sopenharmony_ci self.assertEqual(sum((i / 2 for i in range(10)), 1000), 1022.5) 16247db96d56Sopenharmony_ci self.assertEqual(sum((i / 2 for i in range(10)), 1000.25), 1022.75) 16257db96d56Sopenharmony_ci self.assertEqual(sum([0.5, 1]), 1.5) 16267db96d56Sopenharmony_ci self.assertEqual(sum([1, 0.5]), 1.5) 16277db96d56Sopenharmony_ci self.assertEqual(repr(sum([-0.0])), '0.0') 16287db96d56Sopenharmony_ci self.assertEqual(repr(sum([-0.0], -0.0)), '-0.0') 16297db96d56Sopenharmony_ci self.assertEqual(repr(sum([], -0.0)), '-0.0') 16307db96d56Sopenharmony_ci 16317db96d56Sopenharmony_ci self.assertRaises(TypeError, sum) 16327db96d56Sopenharmony_ci self.assertRaises(TypeError, sum, 42) 16337db96d56Sopenharmony_ci self.assertRaises(TypeError, sum, ['a', 'b', 'c']) 16347db96d56Sopenharmony_ci self.assertRaises(TypeError, sum, ['a', 'b', 'c'], '') 16357db96d56Sopenharmony_ci self.assertRaises(TypeError, sum, [b'a', b'c'], b'') 16367db96d56Sopenharmony_ci values = [bytearray(b'a'), bytearray(b'b')] 16377db96d56Sopenharmony_ci self.assertRaises(TypeError, sum, values, bytearray(b'')) 16387db96d56Sopenharmony_ci self.assertRaises(TypeError, sum, [[1], [2], [3]]) 16397db96d56Sopenharmony_ci self.assertRaises(TypeError, sum, [{2:3}]) 16407db96d56Sopenharmony_ci self.assertRaises(TypeError, sum, [{2:3}]*2, {2:3}) 16417db96d56Sopenharmony_ci self.assertRaises(TypeError, sum, [], '') 16427db96d56Sopenharmony_ci self.assertRaises(TypeError, sum, [], b'') 16437db96d56Sopenharmony_ci self.assertRaises(TypeError, sum, [], bytearray()) 16447db96d56Sopenharmony_ci 16457db96d56Sopenharmony_ci class BadSeq: 16467db96d56Sopenharmony_ci def __getitem__(self, index): 16477db96d56Sopenharmony_ci raise ValueError 16487db96d56Sopenharmony_ci self.assertRaises(ValueError, sum, BadSeq()) 16497db96d56Sopenharmony_ci 16507db96d56Sopenharmony_ci empty = [] 16517db96d56Sopenharmony_ci sum(([x] for x in range(10)), empty) 16527db96d56Sopenharmony_ci self.assertEqual(empty, []) 16537db96d56Sopenharmony_ci 16547db96d56Sopenharmony_ci def test_type(self): 16557db96d56Sopenharmony_ci self.assertEqual(type(''), type('123')) 16567db96d56Sopenharmony_ci self.assertNotEqual(type(''), type(())) 16577db96d56Sopenharmony_ci 16587db96d56Sopenharmony_ci # We don't want self in vars(), so these are static methods 16597db96d56Sopenharmony_ci 16607db96d56Sopenharmony_ci @staticmethod 16617db96d56Sopenharmony_ci def get_vars_f0(): 16627db96d56Sopenharmony_ci return vars() 16637db96d56Sopenharmony_ci 16647db96d56Sopenharmony_ci @staticmethod 16657db96d56Sopenharmony_ci def get_vars_f2(): 16667db96d56Sopenharmony_ci BuiltinTest.get_vars_f0() 16677db96d56Sopenharmony_ci a = 1 16687db96d56Sopenharmony_ci b = 2 16697db96d56Sopenharmony_ci return vars() 16707db96d56Sopenharmony_ci 16717db96d56Sopenharmony_ci class C_get_vars(object): 16727db96d56Sopenharmony_ci def getDict(self): 16737db96d56Sopenharmony_ci return {'a':2} 16747db96d56Sopenharmony_ci __dict__ = property(fget=getDict) 16757db96d56Sopenharmony_ci 16767db96d56Sopenharmony_ci def test_vars(self): 16777db96d56Sopenharmony_ci self.assertEqual(set(vars()), set(dir())) 16787db96d56Sopenharmony_ci self.assertEqual(set(vars(sys)), set(dir(sys))) 16797db96d56Sopenharmony_ci self.assertEqual(self.get_vars_f0(), {}) 16807db96d56Sopenharmony_ci self.assertEqual(self.get_vars_f2(), {'a': 1, 'b': 2}) 16817db96d56Sopenharmony_ci self.assertRaises(TypeError, vars, 42, 42) 16827db96d56Sopenharmony_ci self.assertRaises(TypeError, vars, 42) 16837db96d56Sopenharmony_ci self.assertEqual(vars(self.C_get_vars()), {'a':2}) 16847db96d56Sopenharmony_ci 16857db96d56Sopenharmony_ci def iter_error(self, iterable, error): 16867db96d56Sopenharmony_ci """Collect `iterable` into a list, catching an expected `error`.""" 16877db96d56Sopenharmony_ci items = [] 16887db96d56Sopenharmony_ci with self.assertRaises(error): 16897db96d56Sopenharmony_ci for item in iterable: 16907db96d56Sopenharmony_ci items.append(item) 16917db96d56Sopenharmony_ci return items 16927db96d56Sopenharmony_ci 16937db96d56Sopenharmony_ci def test_zip(self): 16947db96d56Sopenharmony_ci a = (1, 2, 3) 16957db96d56Sopenharmony_ci b = (4, 5, 6) 16967db96d56Sopenharmony_ci t = [(1, 4), (2, 5), (3, 6)] 16977db96d56Sopenharmony_ci self.assertEqual(list(zip(a, b)), t) 16987db96d56Sopenharmony_ci b = [4, 5, 6] 16997db96d56Sopenharmony_ci self.assertEqual(list(zip(a, b)), t) 17007db96d56Sopenharmony_ci b = (4, 5, 6, 7) 17017db96d56Sopenharmony_ci self.assertEqual(list(zip(a, b)), t) 17027db96d56Sopenharmony_ci class I: 17037db96d56Sopenharmony_ci def __getitem__(self, i): 17047db96d56Sopenharmony_ci if i < 0 or i > 2: raise IndexError 17057db96d56Sopenharmony_ci return i + 4 17067db96d56Sopenharmony_ci self.assertEqual(list(zip(a, I())), t) 17077db96d56Sopenharmony_ci self.assertEqual(list(zip()), []) 17087db96d56Sopenharmony_ci self.assertEqual(list(zip(*[])), []) 17097db96d56Sopenharmony_ci self.assertRaises(TypeError, zip, None) 17107db96d56Sopenharmony_ci class G: 17117db96d56Sopenharmony_ci pass 17127db96d56Sopenharmony_ci self.assertRaises(TypeError, zip, a, G()) 17137db96d56Sopenharmony_ci self.assertRaises(RuntimeError, zip, a, TestFailingIter()) 17147db96d56Sopenharmony_ci 17157db96d56Sopenharmony_ci # Make sure zip doesn't try to allocate a billion elements for the 17167db96d56Sopenharmony_ci # result list when one of its arguments doesn't say how long it is. 17177db96d56Sopenharmony_ci # A MemoryError is the most likely failure mode. 17187db96d56Sopenharmony_ci class SequenceWithoutALength: 17197db96d56Sopenharmony_ci def __getitem__(self, i): 17207db96d56Sopenharmony_ci if i == 5: 17217db96d56Sopenharmony_ci raise IndexError 17227db96d56Sopenharmony_ci else: 17237db96d56Sopenharmony_ci return i 17247db96d56Sopenharmony_ci self.assertEqual( 17257db96d56Sopenharmony_ci list(zip(SequenceWithoutALength(), range(2**30))), 17267db96d56Sopenharmony_ci list(enumerate(range(5))) 17277db96d56Sopenharmony_ci ) 17287db96d56Sopenharmony_ci 17297db96d56Sopenharmony_ci class BadSeq: 17307db96d56Sopenharmony_ci def __getitem__(self, i): 17317db96d56Sopenharmony_ci if i == 5: 17327db96d56Sopenharmony_ci raise ValueError 17337db96d56Sopenharmony_ci else: 17347db96d56Sopenharmony_ci return i 17357db96d56Sopenharmony_ci self.assertRaises(ValueError, list, zip(BadSeq(), BadSeq())) 17367db96d56Sopenharmony_ci 17377db96d56Sopenharmony_ci def test_zip_pickle(self): 17387db96d56Sopenharmony_ci a = (1, 2, 3) 17397db96d56Sopenharmony_ci b = (4, 5, 6) 17407db96d56Sopenharmony_ci t = [(1, 4), (2, 5), (3, 6)] 17417db96d56Sopenharmony_ci for proto in range(pickle.HIGHEST_PROTOCOL + 1): 17427db96d56Sopenharmony_ci z1 = zip(a, b) 17437db96d56Sopenharmony_ci self.check_iter_pickle(z1, t, proto) 17447db96d56Sopenharmony_ci 17457db96d56Sopenharmony_ci def test_zip_pickle_strict(self): 17467db96d56Sopenharmony_ci a = (1, 2, 3) 17477db96d56Sopenharmony_ci b = (4, 5, 6) 17487db96d56Sopenharmony_ci t = [(1, 4), (2, 5), (3, 6)] 17497db96d56Sopenharmony_ci for proto in range(pickle.HIGHEST_PROTOCOL + 1): 17507db96d56Sopenharmony_ci z1 = zip(a, b, strict=True) 17517db96d56Sopenharmony_ci self.check_iter_pickle(z1, t, proto) 17527db96d56Sopenharmony_ci 17537db96d56Sopenharmony_ci def test_zip_pickle_strict_fail(self): 17547db96d56Sopenharmony_ci a = (1, 2, 3) 17557db96d56Sopenharmony_ci b = (4, 5, 6, 7) 17567db96d56Sopenharmony_ci t = [(1, 4), (2, 5), (3, 6)] 17577db96d56Sopenharmony_ci for proto in range(pickle.HIGHEST_PROTOCOL + 1): 17587db96d56Sopenharmony_ci z1 = zip(a, b, strict=True) 17597db96d56Sopenharmony_ci z2 = pickle.loads(pickle.dumps(z1, proto)) 17607db96d56Sopenharmony_ci self.assertEqual(self.iter_error(z1, ValueError), t) 17617db96d56Sopenharmony_ci self.assertEqual(self.iter_error(z2, ValueError), t) 17627db96d56Sopenharmony_ci 17637db96d56Sopenharmony_ci def test_zip_bad_iterable(self): 17647db96d56Sopenharmony_ci exception = TypeError() 17657db96d56Sopenharmony_ci 17667db96d56Sopenharmony_ci class BadIterable: 17677db96d56Sopenharmony_ci def __iter__(self): 17687db96d56Sopenharmony_ci raise exception 17697db96d56Sopenharmony_ci 17707db96d56Sopenharmony_ci with self.assertRaises(TypeError) as cm: 17717db96d56Sopenharmony_ci zip(BadIterable()) 17727db96d56Sopenharmony_ci 17737db96d56Sopenharmony_ci self.assertIs(cm.exception, exception) 17747db96d56Sopenharmony_ci 17757db96d56Sopenharmony_ci def test_zip_strict(self): 17767db96d56Sopenharmony_ci self.assertEqual(tuple(zip((1, 2, 3), 'abc', strict=True)), 17777db96d56Sopenharmony_ci ((1, 'a'), (2, 'b'), (3, 'c'))) 17787db96d56Sopenharmony_ci self.assertRaises(ValueError, tuple, 17797db96d56Sopenharmony_ci zip((1, 2, 3, 4), 'abc', strict=True)) 17807db96d56Sopenharmony_ci self.assertRaises(ValueError, tuple, 17817db96d56Sopenharmony_ci zip((1, 2), 'abc', strict=True)) 17827db96d56Sopenharmony_ci self.assertRaises(ValueError, tuple, 17837db96d56Sopenharmony_ci zip((1, 2), (1, 2), 'abc', strict=True)) 17847db96d56Sopenharmony_ci 17857db96d56Sopenharmony_ci def test_zip_strict_iterators(self): 17867db96d56Sopenharmony_ci x = iter(range(5)) 17877db96d56Sopenharmony_ci y = [0] 17887db96d56Sopenharmony_ci z = iter(range(5)) 17897db96d56Sopenharmony_ci self.assertRaises(ValueError, list, 17907db96d56Sopenharmony_ci (zip(x, y, z, strict=True))) 17917db96d56Sopenharmony_ci self.assertEqual(next(x), 2) 17927db96d56Sopenharmony_ci self.assertEqual(next(z), 1) 17937db96d56Sopenharmony_ci 17947db96d56Sopenharmony_ci def test_zip_strict_error_handling(self): 17957db96d56Sopenharmony_ci 17967db96d56Sopenharmony_ci class Error(Exception): 17977db96d56Sopenharmony_ci pass 17987db96d56Sopenharmony_ci 17997db96d56Sopenharmony_ci class Iter: 18007db96d56Sopenharmony_ci def __init__(self, size): 18017db96d56Sopenharmony_ci self.size = size 18027db96d56Sopenharmony_ci def __iter__(self): 18037db96d56Sopenharmony_ci return self 18047db96d56Sopenharmony_ci def __next__(self): 18057db96d56Sopenharmony_ci self.size -= 1 18067db96d56Sopenharmony_ci if self.size < 0: 18077db96d56Sopenharmony_ci raise Error 18087db96d56Sopenharmony_ci return self.size 18097db96d56Sopenharmony_ci 18107db96d56Sopenharmony_ci l1 = self.iter_error(zip("AB", Iter(1), strict=True), Error) 18117db96d56Sopenharmony_ci self.assertEqual(l1, [("A", 0)]) 18127db96d56Sopenharmony_ci l2 = self.iter_error(zip("AB", Iter(2), "A", strict=True), ValueError) 18137db96d56Sopenharmony_ci self.assertEqual(l2, [("A", 1, "A")]) 18147db96d56Sopenharmony_ci l3 = self.iter_error(zip("AB", Iter(2), "ABC", strict=True), Error) 18157db96d56Sopenharmony_ci self.assertEqual(l3, [("A", 1, "A"), ("B", 0, "B")]) 18167db96d56Sopenharmony_ci l4 = self.iter_error(zip("AB", Iter(3), strict=True), ValueError) 18177db96d56Sopenharmony_ci self.assertEqual(l4, [("A", 2), ("B", 1)]) 18187db96d56Sopenharmony_ci l5 = self.iter_error(zip(Iter(1), "AB", strict=True), Error) 18197db96d56Sopenharmony_ci self.assertEqual(l5, [(0, "A")]) 18207db96d56Sopenharmony_ci l6 = self.iter_error(zip(Iter(2), "A", strict=True), ValueError) 18217db96d56Sopenharmony_ci self.assertEqual(l6, [(1, "A")]) 18227db96d56Sopenharmony_ci l7 = self.iter_error(zip(Iter(2), "ABC", strict=True), Error) 18237db96d56Sopenharmony_ci self.assertEqual(l7, [(1, "A"), (0, "B")]) 18247db96d56Sopenharmony_ci l8 = self.iter_error(zip(Iter(3), "AB", strict=True), ValueError) 18257db96d56Sopenharmony_ci self.assertEqual(l8, [(2, "A"), (1, "B")]) 18267db96d56Sopenharmony_ci 18277db96d56Sopenharmony_ci def test_zip_strict_error_handling_stopiteration(self): 18287db96d56Sopenharmony_ci 18297db96d56Sopenharmony_ci class Iter: 18307db96d56Sopenharmony_ci def __init__(self, size): 18317db96d56Sopenharmony_ci self.size = size 18327db96d56Sopenharmony_ci def __iter__(self): 18337db96d56Sopenharmony_ci return self 18347db96d56Sopenharmony_ci def __next__(self): 18357db96d56Sopenharmony_ci self.size -= 1 18367db96d56Sopenharmony_ci if self.size < 0: 18377db96d56Sopenharmony_ci raise StopIteration 18387db96d56Sopenharmony_ci return self.size 18397db96d56Sopenharmony_ci 18407db96d56Sopenharmony_ci l1 = self.iter_error(zip("AB", Iter(1), strict=True), ValueError) 18417db96d56Sopenharmony_ci self.assertEqual(l1, [("A", 0)]) 18427db96d56Sopenharmony_ci l2 = self.iter_error(zip("AB", Iter(2), "A", strict=True), ValueError) 18437db96d56Sopenharmony_ci self.assertEqual(l2, [("A", 1, "A")]) 18447db96d56Sopenharmony_ci l3 = self.iter_error(zip("AB", Iter(2), "ABC", strict=True), ValueError) 18457db96d56Sopenharmony_ci self.assertEqual(l3, [("A", 1, "A"), ("B", 0, "B")]) 18467db96d56Sopenharmony_ci l4 = self.iter_error(zip("AB", Iter(3), strict=True), ValueError) 18477db96d56Sopenharmony_ci self.assertEqual(l4, [("A", 2), ("B", 1)]) 18487db96d56Sopenharmony_ci l5 = self.iter_error(zip(Iter(1), "AB", strict=True), ValueError) 18497db96d56Sopenharmony_ci self.assertEqual(l5, [(0, "A")]) 18507db96d56Sopenharmony_ci l6 = self.iter_error(zip(Iter(2), "A", strict=True), ValueError) 18517db96d56Sopenharmony_ci self.assertEqual(l6, [(1, "A")]) 18527db96d56Sopenharmony_ci l7 = self.iter_error(zip(Iter(2), "ABC", strict=True), ValueError) 18537db96d56Sopenharmony_ci self.assertEqual(l7, [(1, "A"), (0, "B")]) 18547db96d56Sopenharmony_ci l8 = self.iter_error(zip(Iter(3), "AB", strict=True), ValueError) 18557db96d56Sopenharmony_ci self.assertEqual(l8, [(2, "A"), (1, "B")]) 18567db96d56Sopenharmony_ci 18577db96d56Sopenharmony_ci @support.cpython_only 18587db96d56Sopenharmony_ci def test_zip_result_gc(self): 18597db96d56Sopenharmony_ci # bpo-42536: zip's tuple-reuse speed trick breaks the GC's assumptions 18607db96d56Sopenharmony_ci # about what can be untracked. Make sure we re-track result tuples 18617db96d56Sopenharmony_ci # whenever we reuse them. 18627db96d56Sopenharmony_ci it = zip([[]]) 18637db96d56Sopenharmony_ci gc.collect() 18647db96d56Sopenharmony_ci # That GC collection probably untracked the recycled internal result 18657db96d56Sopenharmony_ci # tuple, which is initialized to (None,). Make sure it's re-tracked when 18667db96d56Sopenharmony_ci # it's mutated and returned from __next__: 18677db96d56Sopenharmony_ci self.assertTrue(gc.is_tracked(next(it))) 18687db96d56Sopenharmony_ci 18697db96d56Sopenharmony_ci def test_format(self): 18707db96d56Sopenharmony_ci # Test the basic machinery of the format() builtin. Don't test 18717db96d56Sopenharmony_ci # the specifics of the various formatters 18727db96d56Sopenharmony_ci self.assertEqual(format(3, ''), '3') 18737db96d56Sopenharmony_ci 18747db96d56Sopenharmony_ci # Returns some classes to use for various tests. There's 18757db96d56Sopenharmony_ci # an old-style version, and a new-style version 18767db96d56Sopenharmony_ci def classes_new(): 18777db96d56Sopenharmony_ci class A(object): 18787db96d56Sopenharmony_ci def __init__(self, x): 18797db96d56Sopenharmony_ci self.x = x 18807db96d56Sopenharmony_ci def __format__(self, format_spec): 18817db96d56Sopenharmony_ci return str(self.x) + format_spec 18827db96d56Sopenharmony_ci class DerivedFromA(A): 18837db96d56Sopenharmony_ci pass 18847db96d56Sopenharmony_ci 18857db96d56Sopenharmony_ci class Simple(object): pass 18867db96d56Sopenharmony_ci class DerivedFromSimple(Simple): 18877db96d56Sopenharmony_ci def __init__(self, x): 18887db96d56Sopenharmony_ci self.x = x 18897db96d56Sopenharmony_ci def __format__(self, format_spec): 18907db96d56Sopenharmony_ci return str(self.x) + format_spec 18917db96d56Sopenharmony_ci class DerivedFromSimple2(DerivedFromSimple): pass 18927db96d56Sopenharmony_ci return A, DerivedFromA, DerivedFromSimple, DerivedFromSimple2 18937db96d56Sopenharmony_ci 18947db96d56Sopenharmony_ci def class_test(A, DerivedFromA, DerivedFromSimple, DerivedFromSimple2): 18957db96d56Sopenharmony_ci self.assertEqual(format(A(3), 'spec'), '3spec') 18967db96d56Sopenharmony_ci self.assertEqual(format(DerivedFromA(4), 'spec'), '4spec') 18977db96d56Sopenharmony_ci self.assertEqual(format(DerivedFromSimple(5), 'abc'), '5abc') 18987db96d56Sopenharmony_ci self.assertEqual(format(DerivedFromSimple2(10), 'abcdef'), 18997db96d56Sopenharmony_ci '10abcdef') 19007db96d56Sopenharmony_ci 19017db96d56Sopenharmony_ci class_test(*classes_new()) 19027db96d56Sopenharmony_ci 19037db96d56Sopenharmony_ci def empty_format_spec(value): 19047db96d56Sopenharmony_ci # test that: 19057db96d56Sopenharmony_ci # format(x, '') == str(x) 19067db96d56Sopenharmony_ci # format(x) == str(x) 19077db96d56Sopenharmony_ci self.assertEqual(format(value, ""), str(value)) 19087db96d56Sopenharmony_ci self.assertEqual(format(value), str(value)) 19097db96d56Sopenharmony_ci 19107db96d56Sopenharmony_ci # for builtin types, format(x, "") == str(x) 19117db96d56Sopenharmony_ci empty_format_spec(17**13) 19127db96d56Sopenharmony_ci empty_format_spec(1.0) 19137db96d56Sopenharmony_ci empty_format_spec(3.1415e104) 19147db96d56Sopenharmony_ci empty_format_spec(-3.1415e104) 19157db96d56Sopenharmony_ci empty_format_spec(3.1415e-104) 19167db96d56Sopenharmony_ci empty_format_spec(-3.1415e-104) 19177db96d56Sopenharmony_ci empty_format_spec(object) 19187db96d56Sopenharmony_ci empty_format_spec(None) 19197db96d56Sopenharmony_ci 19207db96d56Sopenharmony_ci # TypeError because self.__format__ returns the wrong type 19217db96d56Sopenharmony_ci class BadFormatResult: 19227db96d56Sopenharmony_ci def __format__(self, format_spec): 19237db96d56Sopenharmony_ci return 1.0 19247db96d56Sopenharmony_ci self.assertRaises(TypeError, format, BadFormatResult(), "") 19257db96d56Sopenharmony_ci 19267db96d56Sopenharmony_ci # TypeError because format_spec is not unicode or str 19277db96d56Sopenharmony_ci self.assertRaises(TypeError, format, object(), 4) 19287db96d56Sopenharmony_ci self.assertRaises(TypeError, format, object(), object()) 19297db96d56Sopenharmony_ci 19307db96d56Sopenharmony_ci # tests for object.__format__ really belong elsewhere, but 19317db96d56Sopenharmony_ci # there's no good place to put them 19327db96d56Sopenharmony_ci x = object().__format__('') 19337db96d56Sopenharmony_ci self.assertTrue(x.startswith('<object object at')) 19347db96d56Sopenharmony_ci 19357db96d56Sopenharmony_ci # first argument to object.__format__ must be string 19367db96d56Sopenharmony_ci self.assertRaises(TypeError, object().__format__, 3) 19377db96d56Sopenharmony_ci self.assertRaises(TypeError, object().__format__, object()) 19387db96d56Sopenharmony_ci self.assertRaises(TypeError, object().__format__, None) 19397db96d56Sopenharmony_ci 19407db96d56Sopenharmony_ci # -------------------------------------------------------------------- 19417db96d56Sopenharmony_ci # Issue #7994: object.__format__ with a non-empty format string is 19427db96d56Sopenharmony_ci # disallowed 19437db96d56Sopenharmony_ci class A: 19447db96d56Sopenharmony_ci def __format__(self, fmt_str): 19457db96d56Sopenharmony_ci return format('', fmt_str) 19467db96d56Sopenharmony_ci 19477db96d56Sopenharmony_ci self.assertEqual(format(A()), '') 19487db96d56Sopenharmony_ci self.assertEqual(format(A(), ''), '') 19497db96d56Sopenharmony_ci self.assertEqual(format(A(), 's'), '') 19507db96d56Sopenharmony_ci 19517db96d56Sopenharmony_ci class B: 19527db96d56Sopenharmony_ci pass 19537db96d56Sopenharmony_ci 19547db96d56Sopenharmony_ci class C(object): 19557db96d56Sopenharmony_ci pass 19567db96d56Sopenharmony_ci 19577db96d56Sopenharmony_ci for cls in [object, B, C]: 19587db96d56Sopenharmony_ci obj = cls() 19597db96d56Sopenharmony_ci self.assertEqual(format(obj), str(obj)) 19607db96d56Sopenharmony_ci self.assertEqual(format(obj, ''), str(obj)) 19617db96d56Sopenharmony_ci with self.assertRaisesRegex(TypeError, 19627db96d56Sopenharmony_ci r'\b%s\b' % re.escape(cls.__name__)): 19637db96d56Sopenharmony_ci format(obj, 's') 19647db96d56Sopenharmony_ci # -------------------------------------------------------------------- 19657db96d56Sopenharmony_ci 19667db96d56Sopenharmony_ci # make sure we can take a subclass of str as a format spec 19677db96d56Sopenharmony_ci class DerivedFromStr(str): pass 19687db96d56Sopenharmony_ci self.assertEqual(format(0, DerivedFromStr('10')), ' 0') 19697db96d56Sopenharmony_ci 19707db96d56Sopenharmony_ci def test_bin(self): 19717db96d56Sopenharmony_ci self.assertEqual(bin(0), '0b0') 19727db96d56Sopenharmony_ci self.assertEqual(bin(1), '0b1') 19737db96d56Sopenharmony_ci self.assertEqual(bin(-1), '-0b1') 19747db96d56Sopenharmony_ci self.assertEqual(bin(2**65), '0b1' + '0' * 65) 19757db96d56Sopenharmony_ci self.assertEqual(bin(2**65-1), '0b' + '1' * 65) 19767db96d56Sopenharmony_ci self.assertEqual(bin(-(2**65)), '-0b1' + '0' * 65) 19777db96d56Sopenharmony_ci self.assertEqual(bin(-(2**65-1)), '-0b' + '1' * 65) 19787db96d56Sopenharmony_ci 19797db96d56Sopenharmony_ci def test_bytearray_translate(self): 19807db96d56Sopenharmony_ci x = bytearray(b"abc") 19817db96d56Sopenharmony_ci self.assertRaises(ValueError, x.translate, b"1", 1) 19827db96d56Sopenharmony_ci self.assertRaises(TypeError, x.translate, b"1"*256, 1) 19837db96d56Sopenharmony_ci 19847db96d56Sopenharmony_ci def test_bytearray_extend_error(self): 19857db96d56Sopenharmony_ci array = bytearray() 19867db96d56Sopenharmony_ci bad_iter = map(int, "X") 19877db96d56Sopenharmony_ci self.assertRaises(ValueError, array.extend, bad_iter) 19887db96d56Sopenharmony_ci 19897db96d56Sopenharmony_ci def test_construct_singletons(self): 19907db96d56Sopenharmony_ci for const in None, Ellipsis, NotImplemented: 19917db96d56Sopenharmony_ci tp = type(const) 19927db96d56Sopenharmony_ci self.assertIs(tp(), const) 19937db96d56Sopenharmony_ci self.assertRaises(TypeError, tp, 1, 2) 19947db96d56Sopenharmony_ci self.assertRaises(TypeError, tp, a=1, b=2) 19957db96d56Sopenharmony_ci 19967db96d56Sopenharmony_ci def test_warning_notimplemented(self): 19977db96d56Sopenharmony_ci # Issue #35712: NotImplemented is a sentinel value that should never 19987db96d56Sopenharmony_ci # be evaluated in a boolean context (virtually all such use cases 19997db96d56Sopenharmony_ci # are a result of accidental misuse implementing rich comparison 20007db96d56Sopenharmony_ci # operations in terms of one another). 20017db96d56Sopenharmony_ci # For the time being, it will continue to evaluate as a true value, but 20027db96d56Sopenharmony_ci # issue a deprecation warning (with the eventual intent to make it 20037db96d56Sopenharmony_ci # a TypeError). 20047db96d56Sopenharmony_ci self.assertWarns(DeprecationWarning, bool, NotImplemented) 20057db96d56Sopenharmony_ci with self.assertWarns(DeprecationWarning): 20067db96d56Sopenharmony_ci self.assertTrue(NotImplemented) 20077db96d56Sopenharmony_ci with self.assertWarns(DeprecationWarning): 20087db96d56Sopenharmony_ci self.assertFalse(not NotImplemented) 20097db96d56Sopenharmony_ci 20107db96d56Sopenharmony_ci 20117db96d56Sopenharmony_ciclass TestBreakpoint(unittest.TestCase): 20127db96d56Sopenharmony_ci def setUp(self): 20137db96d56Sopenharmony_ci # These tests require a clean slate environment. For example, if the 20147db96d56Sopenharmony_ci # test suite is run with $PYTHONBREAKPOINT set to something else, it 20157db96d56Sopenharmony_ci # will mess up these tests. Similarly for sys.breakpointhook. 20167db96d56Sopenharmony_ci # Cleaning the slate here means you can't use breakpoint() to debug 20177db96d56Sopenharmony_ci # these tests, but I think that's okay. Just use pdb.set_trace() if 20187db96d56Sopenharmony_ci # you must. 20197db96d56Sopenharmony_ci self.resources = ExitStack() 20207db96d56Sopenharmony_ci self.addCleanup(self.resources.close) 20217db96d56Sopenharmony_ci self.env = self.resources.enter_context(EnvironmentVarGuard()) 20227db96d56Sopenharmony_ci del self.env['PYTHONBREAKPOINT'] 20237db96d56Sopenharmony_ci self.resources.enter_context( 20247db96d56Sopenharmony_ci swap_attr(sys, 'breakpointhook', sys.__breakpointhook__)) 20257db96d56Sopenharmony_ci 20267db96d56Sopenharmony_ci def test_breakpoint(self): 20277db96d56Sopenharmony_ci with patch('pdb.set_trace') as mock: 20287db96d56Sopenharmony_ci breakpoint() 20297db96d56Sopenharmony_ci mock.assert_called_once() 20307db96d56Sopenharmony_ci 20317db96d56Sopenharmony_ci def test_breakpoint_with_breakpointhook_set(self): 20327db96d56Sopenharmony_ci my_breakpointhook = MagicMock() 20337db96d56Sopenharmony_ci sys.breakpointhook = my_breakpointhook 20347db96d56Sopenharmony_ci breakpoint() 20357db96d56Sopenharmony_ci my_breakpointhook.assert_called_once_with() 20367db96d56Sopenharmony_ci 20377db96d56Sopenharmony_ci def test_breakpoint_with_breakpointhook_reset(self): 20387db96d56Sopenharmony_ci my_breakpointhook = MagicMock() 20397db96d56Sopenharmony_ci sys.breakpointhook = my_breakpointhook 20407db96d56Sopenharmony_ci breakpoint() 20417db96d56Sopenharmony_ci my_breakpointhook.assert_called_once_with() 20427db96d56Sopenharmony_ci # Reset the hook and it will not be called again. 20437db96d56Sopenharmony_ci sys.breakpointhook = sys.__breakpointhook__ 20447db96d56Sopenharmony_ci with patch('pdb.set_trace') as mock: 20457db96d56Sopenharmony_ci breakpoint() 20467db96d56Sopenharmony_ci mock.assert_called_once_with() 20477db96d56Sopenharmony_ci my_breakpointhook.assert_called_once_with() 20487db96d56Sopenharmony_ci 20497db96d56Sopenharmony_ci def test_breakpoint_with_args_and_keywords(self): 20507db96d56Sopenharmony_ci my_breakpointhook = MagicMock() 20517db96d56Sopenharmony_ci sys.breakpointhook = my_breakpointhook 20527db96d56Sopenharmony_ci breakpoint(1, 2, 3, four=4, five=5) 20537db96d56Sopenharmony_ci my_breakpointhook.assert_called_once_with(1, 2, 3, four=4, five=5) 20547db96d56Sopenharmony_ci 20557db96d56Sopenharmony_ci def test_breakpoint_with_passthru_error(self): 20567db96d56Sopenharmony_ci def my_breakpointhook(): 20577db96d56Sopenharmony_ci pass 20587db96d56Sopenharmony_ci sys.breakpointhook = my_breakpointhook 20597db96d56Sopenharmony_ci self.assertRaises(TypeError, breakpoint, 1, 2, 3, four=4, five=5) 20607db96d56Sopenharmony_ci 20617db96d56Sopenharmony_ci @unittest.skipIf(sys.flags.ignore_environment, '-E was given') 20627db96d56Sopenharmony_ci def test_envar_good_path_builtin(self): 20637db96d56Sopenharmony_ci self.env['PYTHONBREAKPOINT'] = 'int' 20647db96d56Sopenharmony_ci with patch('builtins.int') as mock: 20657db96d56Sopenharmony_ci breakpoint('7') 20667db96d56Sopenharmony_ci mock.assert_called_once_with('7') 20677db96d56Sopenharmony_ci 20687db96d56Sopenharmony_ci @unittest.skipIf(sys.flags.ignore_environment, '-E was given') 20697db96d56Sopenharmony_ci def test_envar_good_path_other(self): 20707db96d56Sopenharmony_ci self.env['PYTHONBREAKPOINT'] = 'sys.exit' 20717db96d56Sopenharmony_ci with patch('sys.exit') as mock: 20727db96d56Sopenharmony_ci breakpoint() 20737db96d56Sopenharmony_ci mock.assert_called_once_with() 20747db96d56Sopenharmony_ci 20757db96d56Sopenharmony_ci @unittest.skipIf(sys.flags.ignore_environment, '-E was given') 20767db96d56Sopenharmony_ci def test_envar_good_path_noop_0(self): 20777db96d56Sopenharmony_ci self.env['PYTHONBREAKPOINT'] = '0' 20787db96d56Sopenharmony_ci with patch('pdb.set_trace') as mock: 20797db96d56Sopenharmony_ci breakpoint() 20807db96d56Sopenharmony_ci mock.assert_not_called() 20817db96d56Sopenharmony_ci 20827db96d56Sopenharmony_ci def test_envar_good_path_empty_string(self): 20837db96d56Sopenharmony_ci # PYTHONBREAKPOINT='' is the same as it not being set. 20847db96d56Sopenharmony_ci self.env['PYTHONBREAKPOINT'] = '' 20857db96d56Sopenharmony_ci with patch('pdb.set_trace') as mock: 20867db96d56Sopenharmony_ci breakpoint() 20877db96d56Sopenharmony_ci mock.assert_called_once_with() 20887db96d56Sopenharmony_ci 20897db96d56Sopenharmony_ci @unittest.skipIf(sys.flags.ignore_environment, '-E was given') 20907db96d56Sopenharmony_ci def test_envar_unimportable(self): 20917db96d56Sopenharmony_ci for envar in ( 20927db96d56Sopenharmony_ci '.', '..', '.foo', 'foo.', '.int', 'int.', 20937db96d56Sopenharmony_ci '.foo.bar', '..foo.bar', '/./', 20947db96d56Sopenharmony_ci 'nosuchbuiltin', 20957db96d56Sopenharmony_ci 'nosuchmodule.nosuchcallable', 20967db96d56Sopenharmony_ci ): 20977db96d56Sopenharmony_ci with self.subTest(envar=envar): 20987db96d56Sopenharmony_ci self.env['PYTHONBREAKPOINT'] = envar 20997db96d56Sopenharmony_ci mock = self.resources.enter_context(patch('pdb.set_trace')) 21007db96d56Sopenharmony_ci w = self.resources.enter_context(check_warnings(quiet=True)) 21017db96d56Sopenharmony_ci breakpoint() 21027db96d56Sopenharmony_ci self.assertEqual( 21037db96d56Sopenharmony_ci str(w.message), 21047db96d56Sopenharmony_ci f'Ignoring unimportable $PYTHONBREAKPOINT: "{envar}"') 21057db96d56Sopenharmony_ci self.assertEqual(w.category, RuntimeWarning) 21067db96d56Sopenharmony_ci mock.assert_not_called() 21077db96d56Sopenharmony_ci 21087db96d56Sopenharmony_ci def test_envar_ignored_when_hook_is_set(self): 21097db96d56Sopenharmony_ci self.env['PYTHONBREAKPOINT'] = 'sys.exit' 21107db96d56Sopenharmony_ci with patch('sys.exit') as mock: 21117db96d56Sopenharmony_ci sys.breakpointhook = int 21127db96d56Sopenharmony_ci breakpoint() 21137db96d56Sopenharmony_ci mock.assert_not_called() 21147db96d56Sopenharmony_ci 21157db96d56Sopenharmony_ci 21167db96d56Sopenharmony_ci@unittest.skipUnless(pty, "the pty and signal modules must be available") 21177db96d56Sopenharmony_ciclass PtyTests(unittest.TestCase): 21187db96d56Sopenharmony_ci """Tests that use a pseudo terminal to guarantee stdin and stdout are 21197db96d56Sopenharmony_ci terminals in the test environment""" 21207db96d56Sopenharmony_ci 21217db96d56Sopenharmony_ci @staticmethod 21227db96d56Sopenharmony_ci def handle_sighup(signum, frame): 21237db96d56Sopenharmony_ci # bpo-40140: if the process is the session leader, os.close(fd) 21247db96d56Sopenharmony_ci # of "pid, fd = pty.fork()" can raise SIGHUP signal: 21257db96d56Sopenharmony_ci # just ignore the signal. 21267db96d56Sopenharmony_ci pass 21277db96d56Sopenharmony_ci 21287db96d56Sopenharmony_ci def run_child(self, child, terminal_input): 21297db96d56Sopenharmony_ci old_sighup = signal.signal(signal.SIGHUP, self.handle_sighup) 21307db96d56Sopenharmony_ci try: 21317db96d56Sopenharmony_ci return self._run_child(child, terminal_input) 21327db96d56Sopenharmony_ci finally: 21337db96d56Sopenharmony_ci signal.signal(signal.SIGHUP, old_sighup) 21347db96d56Sopenharmony_ci 21357db96d56Sopenharmony_ci def _run_child(self, child, terminal_input): 21367db96d56Sopenharmony_ci r, w = os.pipe() # Pipe test results from child back to parent 21377db96d56Sopenharmony_ci try: 21387db96d56Sopenharmony_ci pid, fd = pty.fork() 21397db96d56Sopenharmony_ci except (OSError, AttributeError) as e: 21407db96d56Sopenharmony_ci os.close(r) 21417db96d56Sopenharmony_ci os.close(w) 21427db96d56Sopenharmony_ci self.skipTest("pty.fork() raised {}".format(e)) 21437db96d56Sopenharmony_ci raise 21447db96d56Sopenharmony_ci 21457db96d56Sopenharmony_ci if pid == 0: 21467db96d56Sopenharmony_ci # Child 21477db96d56Sopenharmony_ci try: 21487db96d56Sopenharmony_ci # Make sure we don't get stuck if there's a problem 21497db96d56Sopenharmony_ci signal.alarm(2) 21507db96d56Sopenharmony_ci os.close(r) 21517db96d56Sopenharmony_ci with open(w, "w") as wpipe: 21527db96d56Sopenharmony_ci child(wpipe) 21537db96d56Sopenharmony_ci except: 21547db96d56Sopenharmony_ci traceback.print_exc() 21557db96d56Sopenharmony_ci finally: 21567db96d56Sopenharmony_ci # We don't want to return to unittest... 21577db96d56Sopenharmony_ci os._exit(0) 21587db96d56Sopenharmony_ci 21597db96d56Sopenharmony_ci # Parent 21607db96d56Sopenharmony_ci os.close(w) 21617db96d56Sopenharmony_ci os.write(fd, terminal_input) 21627db96d56Sopenharmony_ci 21637db96d56Sopenharmony_ci # Get results from the pipe 21647db96d56Sopenharmony_ci with open(r, encoding="utf-8") as rpipe: 21657db96d56Sopenharmony_ci lines = [] 21667db96d56Sopenharmony_ci while True: 21677db96d56Sopenharmony_ci line = rpipe.readline().strip() 21687db96d56Sopenharmony_ci if line == "": 21697db96d56Sopenharmony_ci # The other end was closed => the child exited 21707db96d56Sopenharmony_ci break 21717db96d56Sopenharmony_ci lines.append(line) 21727db96d56Sopenharmony_ci 21737db96d56Sopenharmony_ci # Check the result was got and corresponds to the user's terminal input 21747db96d56Sopenharmony_ci if len(lines) != 2: 21757db96d56Sopenharmony_ci # Something went wrong, try to get at stderr 21767db96d56Sopenharmony_ci # Beware of Linux raising EIO when the slave is closed 21777db96d56Sopenharmony_ci child_output = bytearray() 21787db96d56Sopenharmony_ci while True: 21797db96d56Sopenharmony_ci try: 21807db96d56Sopenharmony_ci chunk = os.read(fd, 3000) 21817db96d56Sopenharmony_ci except OSError: # Assume EIO 21827db96d56Sopenharmony_ci break 21837db96d56Sopenharmony_ci if not chunk: 21847db96d56Sopenharmony_ci break 21857db96d56Sopenharmony_ci child_output.extend(chunk) 21867db96d56Sopenharmony_ci os.close(fd) 21877db96d56Sopenharmony_ci child_output = child_output.decode("ascii", "ignore") 21887db96d56Sopenharmony_ci self.fail("got %d lines in pipe but expected 2, child output was:\n%s" 21897db96d56Sopenharmony_ci % (len(lines), child_output)) 21907db96d56Sopenharmony_ci 21917db96d56Sopenharmony_ci # bpo-40155: Close the PTY before waiting for the child process 21927db96d56Sopenharmony_ci # completion, otherwise the child process hangs on AIX. 21937db96d56Sopenharmony_ci os.close(fd) 21947db96d56Sopenharmony_ci 21957db96d56Sopenharmony_ci support.wait_process(pid, exitcode=0) 21967db96d56Sopenharmony_ci 21977db96d56Sopenharmony_ci return lines 21987db96d56Sopenharmony_ci 21997db96d56Sopenharmony_ci def check_input_tty(self, prompt, terminal_input, stdio_encoding=None): 22007db96d56Sopenharmony_ci if not sys.stdin.isatty() or not sys.stdout.isatty(): 22017db96d56Sopenharmony_ci self.skipTest("stdin and stdout must be ttys") 22027db96d56Sopenharmony_ci def child(wpipe): 22037db96d56Sopenharmony_ci # Check the error handlers are accounted for 22047db96d56Sopenharmony_ci if stdio_encoding: 22057db96d56Sopenharmony_ci sys.stdin = io.TextIOWrapper(sys.stdin.detach(), 22067db96d56Sopenharmony_ci encoding=stdio_encoding, 22077db96d56Sopenharmony_ci errors='surrogateescape') 22087db96d56Sopenharmony_ci sys.stdout = io.TextIOWrapper(sys.stdout.detach(), 22097db96d56Sopenharmony_ci encoding=stdio_encoding, 22107db96d56Sopenharmony_ci errors='replace') 22117db96d56Sopenharmony_ci print("tty =", sys.stdin.isatty() and sys.stdout.isatty(), file=wpipe) 22127db96d56Sopenharmony_ci print(ascii(input(prompt)), file=wpipe) 22137db96d56Sopenharmony_ci lines = self.run_child(child, terminal_input + b"\r\n") 22147db96d56Sopenharmony_ci # Check we did exercise the GNU readline path 22157db96d56Sopenharmony_ci self.assertIn(lines[0], {'tty = True', 'tty = False'}) 22167db96d56Sopenharmony_ci if lines[0] != 'tty = True': 22177db96d56Sopenharmony_ci self.skipTest("standard IO in should have been a tty") 22187db96d56Sopenharmony_ci input_result = eval(lines[1]) # ascii() -> eval() roundtrip 22197db96d56Sopenharmony_ci if stdio_encoding: 22207db96d56Sopenharmony_ci expected = terminal_input.decode(stdio_encoding, 'surrogateescape') 22217db96d56Sopenharmony_ci else: 22227db96d56Sopenharmony_ci expected = terminal_input.decode(sys.stdin.encoding) # what else? 22237db96d56Sopenharmony_ci self.assertEqual(input_result, expected) 22247db96d56Sopenharmony_ci 22257db96d56Sopenharmony_ci def test_input_tty(self): 22267db96d56Sopenharmony_ci # Test input() functionality when wired to a tty (the code path 22277db96d56Sopenharmony_ci # is different and invokes GNU readline if available). 22287db96d56Sopenharmony_ci self.check_input_tty("prompt", b"quux") 22297db96d56Sopenharmony_ci 22307db96d56Sopenharmony_ci def skip_if_readline(self): 22317db96d56Sopenharmony_ci # bpo-13886: When the readline module is loaded, PyOS_Readline() uses 22327db96d56Sopenharmony_ci # the readline implementation. In some cases, the Python readline 22337db96d56Sopenharmony_ci # callback rlhandler() is called by readline with a string without 22347db96d56Sopenharmony_ci # non-ASCII characters. Skip tests on non-ASCII characters if the 22357db96d56Sopenharmony_ci # readline module is loaded, since test_builtin is not intented to test 22367db96d56Sopenharmony_ci # the readline module, but the builtins module. 22377db96d56Sopenharmony_ci if 'readline' in sys.modules: 22387db96d56Sopenharmony_ci self.skipTest("the readline module is loaded") 22397db96d56Sopenharmony_ci 22407db96d56Sopenharmony_ci def test_input_tty_non_ascii(self): 22417db96d56Sopenharmony_ci self.skip_if_readline() 22427db96d56Sopenharmony_ci # Check stdin/stdout encoding is used when invoking PyOS_Readline() 22437db96d56Sopenharmony_ci self.check_input_tty("prompté", b"quux\xe9", "utf-8") 22447db96d56Sopenharmony_ci 22457db96d56Sopenharmony_ci def test_input_tty_non_ascii_unicode_errors(self): 22467db96d56Sopenharmony_ci self.skip_if_readline() 22477db96d56Sopenharmony_ci # Check stdin/stdout error handler is used when invoking PyOS_Readline() 22487db96d56Sopenharmony_ci self.check_input_tty("prompté", b"quux\xe9", "ascii") 22497db96d56Sopenharmony_ci 22507db96d56Sopenharmony_ci def test_input_no_stdout_fileno(self): 22517db96d56Sopenharmony_ci # Issue #24402: If stdin is the original terminal but stdout.fileno() 22527db96d56Sopenharmony_ci # fails, do not use the original stdout file descriptor 22537db96d56Sopenharmony_ci def child(wpipe): 22547db96d56Sopenharmony_ci print("stdin.isatty():", sys.stdin.isatty(), file=wpipe) 22557db96d56Sopenharmony_ci sys.stdout = io.StringIO() # Does not support fileno() 22567db96d56Sopenharmony_ci input("prompt") 22577db96d56Sopenharmony_ci print("captured:", ascii(sys.stdout.getvalue()), file=wpipe) 22587db96d56Sopenharmony_ci lines = self.run_child(child, b"quux\r") 22597db96d56Sopenharmony_ci expected = ( 22607db96d56Sopenharmony_ci "stdin.isatty(): True", 22617db96d56Sopenharmony_ci "captured: 'prompt'", 22627db96d56Sopenharmony_ci ) 22637db96d56Sopenharmony_ci self.assertSequenceEqual(lines, expected) 22647db96d56Sopenharmony_ci 22657db96d56Sopenharmony_ciclass TestSorted(unittest.TestCase): 22667db96d56Sopenharmony_ci 22677db96d56Sopenharmony_ci def test_basic(self): 22687db96d56Sopenharmony_ci data = list(range(100)) 22697db96d56Sopenharmony_ci copy = data[:] 22707db96d56Sopenharmony_ci random.shuffle(copy) 22717db96d56Sopenharmony_ci self.assertEqual(data, sorted(copy)) 22727db96d56Sopenharmony_ci self.assertNotEqual(data, copy) 22737db96d56Sopenharmony_ci 22747db96d56Sopenharmony_ci data.reverse() 22757db96d56Sopenharmony_ci random.shuffle(copy) 22767db96d56Sopenharmony_ci self.assertEqual(data, sorted(copy, key=lambda x: -x)) 22777db96d56Sopenharmony_ci self.assertNotEqual(data, copy) 22787db96d56Sopenharmony_ci random.shuffle(copy) 22797db96d56Sopenharmony_ci self.assertEqual(data, sorted(copy, reverse=True)) 22807db96d56Sopenharmony_ci self.assertNotEqual(data, copy) 22817db96d56Sopenharmony_ci 22827db96d56Sopenharmony_ci def test_bad_arguments(self): 22837db96d56Sopenharmony_ci # Issue #29327: The first argument is positional-only. 22847db96d56Sopenharmony_ci sorted([]) 22857db96d56Sopenharmony_ci with self.assertRaises(TypeError): 22867db96d56Sopenharmony_ci sorted(iterable=[]) 22877db96d56Sopenharmony_ci # Other arguments are keyword-only 22887db96d56Sopenharmony_ci sorted([], key=None) 22897db96d56Sopenharmony_ci with self.assertRaises(TypeError): 22907db96d56Sopenharmony_ci sorted([], None) 22917db96d56Sopenharmony_ci 22927db96d56Sopenharmony_ci def test_inputtypes(self): 22937db96d56Sopenharmony_ci s = 'abracadabra' 22947db96d56Sopenharmony_ci types = [list, tuple, str] 22957db96d56Sopenharmony_ci for T in types: 22967db96d56Sopenharmony_ci self.assertEqual(sorted(s), sorted(T(s))) 22977db96d56Sopenharmony_ci 22987db96d56Sopenharmony_ci s = ''.join(set(s)) # unique letters only 22997db96d56Sopenharmony_ci types = [str, set, frozenset, list, tuple, dict.fromkeys] 23007db96d56Sopenharmony_ci for T in types: 23017db96d56Sopenharmony_ci self.assertEqual(sorted(s), sorted(T(s))) 23027db96d56Sopenharmony_ci 23037db96d56Sopenharmony_ci def test_baddecorator(self): 23047db96d56Sopenharmony_ci data = 'The quick Brown fox Jumped over The lazy Dog'.split() 23057db96d56Sopenharmony_ci self.assertRaises(TypeError, sorted, data, None, lambda x,y: 0) 23067db96d56Sopenharmony_ci 23077db96d56Sopenharmony_ci 23087db96d56Sopenharmony_ciclass ShutdownTest(unittest.TestCase): 23097db96d56Sopenharmony_ci 23107db96d56Sopenharmony_ci def test_cleanup(self): 23117db96d56Sopenharmony_ci # Issue #19255: builtins are still available at shutdown 23127db96d56Sopenharmony_ci code = """if 1: 23137db96d56Sopenharmony_ci import builtins 23147db96d56Sopenharmony_ci import sys 23157db96d56Sopenharmony_ci 23167db96d56Sopenharmony_ci class C: 23177db96d56Sopenharmony_ci def __del__(self): 23187db96d56Sopenharmony_ci print("before") 23197db96d56Sopenharmony_ci # Check that builtins still exist 23207db96d56Sopenharmony_ci len(()) 23217db96d56Sopenharmony_ci print("after") 23227db96d56Sopenharmony_ci 23237db96d56Sopenharmony_ci c = C() 23247db96d56Sopenharmony_ci # Make this module survive until builtins and sys are cleaned 23257db96d56Sopenharmony_ci builtins.here = sys.modules[__name__] 23267db96d56Sopenharmony_ci sys.here = sys.modules[__name__] 23277db96d56Sopenharmony_ci # Create a reference loop so that this module needs to go 23287db96d56Sopenharmony_ci # through a GC phase. 23297db96d56Sopenharmony_ci here = sys.modules[__name__] 23307db96d56Sopenharmony_ci """ 23317db96d56Sopenharmony_ci # Issue #20599: Force ASCII encoding to get a codec implemented in C, 23327db96d56Sopenharmony_ci # otherwise the codec may be unloaded before C.__del__() is called, and 23337db96d56Sopenharmony_ci # so print("before") fails because the codec cannot be used to encode 23347db96d56Sopenharmony_ci # "before" to sys.stdout.encoding. For example, on Windows, 23357db96d56Sopenharmony_ci # sys.stdout.encoding is the OEM code page and these code pages are 23367db96d56Sopenharmony_ci # implemented in Python 23377db96d56Sopenharmony_ci rc, out, err = assert_python_ok("-c", code, 23387db96d56Sopenharmony_ci PYTHONIOENCODING="ascii") 23397db96d56Sopenharmony_ci self.assertEqual(["before", "after"], out.decode().splitlines()) 23407db96d56Sopenharmony_ci 23417db96d56Sopenharmony_ci 23427db96d56Sopenharmony_ciclass TestType(unittest.TestCase): 23437db96d56Sopenharmony_ci def test_new_type(self): 23447db96d56Sopenharmony_ci A = type('A', (), {}) 23457db96d56Sopenharmony_ci self.assertEqual(A.__name__, 'A') 23467db96d56Sopenharmony_ci self.assertEqual(A.__qualname__, 'A') 23477db96d56Sopenharmony_ci self.assertEqual(A.__module__, __name__) 23487db96d56Sopenharmony_ci self.assertEqual(A.__bases__, (object,)) 23497db96d56Sopenharmony_ci self.assertIs(A.__base__, object) 23507db96d56Sopenharmony_ci x = A() 23517db96d56Sopenharmony_ci self.assertIs(type(x), A) 23527db96d56Sopenharmony_ci self.assertIs(x.__class__, A) 23537db96d56Sopenharmony_ci 23547db96d56Sopenharmony_ci class B: 23557db96d56Sopenharmony_ci def ham(self): 23567db96d56Sopenharmony_ci return 'ham%d' % self 23577db96d56Sopenharmony_ci C = type('C', (B, int), {'spam': lambda self: 'spam%s' % self}) 23587db96d56Sopenharmony_ci self.assertEqual(C.__name__, 'C') 23597db96d56Sopenharmony_ci self.assertEqual(C.__qualname__, 'C') 23607db96d56Sopenharmony_ci self.assertEqual(C.__module__, __name__) 23617db96d56Sopenharmony_ci self.assertEqual(C.__bases__, (B, int)) 23627db96d56Sopenharmony_ci self.assertIs(C.__base__, int) 23637db96d56Sopenharmony_ci self.assertIn('spam', C.__dict__) 23647db96d56Sopenharmony_ci self.assertNotIn('ham', C.__dict__) 23657db96d56Sopenharmony_ci x = C(42) 23667db96d56Sopenharmony_ci self.assertEqual(x, 42) 23677db96d56Sopenharmony_ci self.assertIs(type(x), C) 23687db96d56Sopenharmony_ci self.assertIs(x.__class__, C) 23697db96d56Sopenharmony_ci self.assertEqual(x.ham(), 'ham42') 23707db96d56Sopenharmony_ci self.assertEqual(x.spam(), 'spam42') 23717db96d56Sopenharmony_ci self.assertEqual(x.to_bytes(2, 'little'), b'\x2a\x00') 23727db96d56Sopenharmony_ci 23737db96d56Sopenharmony_ci def test_type_nokwargs(self): 23747db96d56Sopenharmony_ci with self.assertRaises(TypeError): 23757db96d56Sopenharmony_ci type('a', (), {}, x=5) 23767db96d56Sopenharmony_ci with self.assertRaises(TypeError): 23777db96d56Sopenharmony_ci type('a', (), dict={}) 23787db96d56Sopenharmony_ci 23797db96d56Sopenharmony_ci def test_type_name(self): 23807db96d56Sopenharmony_ci for name in 'A', '\xc4', '\U0001f40d', 'B.A', '42', '': 23817db96d56Sopenharmony_ci with self.subTest(name=name): 23827db96d56Sopenharmony_ci A = type(name, (), {}) 23837db96d56Sopenharmony_ci self.assertEqual(A.__name__, name) 23847db96d56Sopenharmony_ci self.assertEqual(A.__qualname__, name) 23857db96d56Sopenharmony_ci self.assertEqual(A.__module__, __name__) 23867db96d56Sopenharmony_ci with self.assertRaises(ValueError): 23877db96d56Sopenharmony_ci type('A\x00B', (), {}) 23887db96d56Sopenharmony_ci with self.assertRaises(UnicodeEncodeError): 23897db96d56Sopenharmony_ci type('A\udcdcB', (), {}) 23907db96d56Sopenharmony_ci with self.assertRaises(TypeError): 23917db96d56Sopenharmony_ci type(b'A', (), {}) 23927db96d56Sopenharmony_ci 23937db96d56Sopenharmony_ci C = type('C', (), {}) 23947db96d56Sopenharmony_ci for name in 'A', '\xc4', '\U0001f40d', 'B.A', '42', '': 23957db96d56Sopenharmony_ci with self.subTest(name=name): 23967db96d56Sopenharmony_ci C.__name__ = name 23977db96d56Sopenharmony_ci self.assertEqual(C.__name__, name) 23987db96d56Sopenharmony_ci self.assertEqual(C.__qualname__, 'C') 23997db96d56Sopenharmony_ci self.assertEqual(C.__module__, __name__) 24007db96d56Sopenharmony_ci 24017db96d56Sopenharmony_ci A = type('C', (), {}) 24027db96d56Sopenharmony_ci with self.assertRaises(ValueError): 24037db96d56Sopenharmony_ci A.__name__ = 'A\x00B' 24047db96d56Sopenharmony_ci self.assertEqual(A.__name__, 'C') 24057db96d56Sopenharmony_ci with self.assertRaises(UnicodeEncodeError): 24067db96d56Sopenharmony_ci A.__name__ = 'A\udcdcB' 24077db96d56Sopenharmony_ci self.assertEqual(A.__name__, 'C') 24087db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24097db96d56Sopenharmony_ci A.__name__ = b'A' 24107db96d56Sopenharmony_ci self.assertEqual(A.__name__, 'C') 24117db96d56Sopenharmony_ci 24127db96d56Sopenharmony_ci def test_type_qualname(self): 24137db96d56Sopenharmony_ci A = type('A', (), {'__qualname__': 'B.C'}) 24147db96d56Sopenharmony_ci self.assertEqual(A.__name__, 'A') 24157db96d56Sopenharmony_ci self.assertEqual(A.__qualname__, 'B.C') 24167db96d56Sopenharmony_ci self.assertEqual(A.__module__, __name__) 24177db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24187db96d56Sopenharmony_ci type('A', (), {'__qualname__': b'B'}) 24197db96d56Sopenharmony_ci self.assertEqual(A.__qualname__, 'B.C') 24207db96d56Sopenharmony_ci 24217db96d56Sopenharmony_ci A.__qualname__ = 'D.E' 24227db96d56Sopenharmony_ci self.assertEqual(A.__name__, 'A') 24237db96d56Sopenharmony_ci self.assertEqual(A.__qualname__, 'D.E') 24247db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24257db96d56Sopenharmony_ci A.__qualname__ = b'B' 24267db96d56Sopenharmony_ci self.assertEqual(A.__qualname__, 'D.E') 24277db96d56Sopenharmony_ci 24287db96d56Sopenharmony_ci def test_type_doc(self): 24297db96d56Sopenharmony_ci for doc in 'x', '\xc4', '\U0001f40d', 'x\x00y', b'x', 42, None: 24307db96d56Sopenharmony_ci A = type('A', (), {'__doc__': doc}) 24317db96d56Sopenharmony_ci self.assertEqual(A.__doc__, doc) 24327db96d56Sopenharmony_ci with self.assertRaises(UnicodeEncodeError): 24337db96d56Sopenharmony_ci type('A', (), {'__doc__': 'x\udcdcy'}) 24347db96d56Sopenharmony_ci 24357db96d56Sopenharmony_ci A = type('A', (), {}) 24367db96d56Sopenharmony_ci self.assertEqual(A.__doc__, None) 24377db96d56Sopenharmony_ci for doc in 'x', '\xc4', '\U0001f40d', 'x\x00y', 'x\udcdcy', b'x', 42, None: 24387db96d56Sopenharmony_ci A.__doc__ = doc 24397db96d56Sopenharmony_ci self.assertEqual(A.__doc__, doc) 24407db96d56Sopenharmony_ci 24417db96d56Sopenharmony_ci def test_bad_args(self): 24427db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24437db96d56Sopenharmony_ci type() 24447db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24457db96d56Sopenharmony_ci type('A', ()) 24467db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24477db96d56Sopenharmony_ci type('A', (), {}, ()) 24487db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24497db96d56Sopenharmony_ci type('A', (), dict={}) 24507db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24517db96d56Sopenharmony_ci type('A', [], {}) 24527db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24537db96d56Sopenharmony_ci type('A', (), types.MappingProxyType({})) 24547db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24557db96d56Sopenharmony_ci type('A', (None,), {}) 24567db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24577db96d56Sopenharmony_ci type('A', (bool,), {}) 24587db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24597db96d56Sopenharmony_ci type('A', (int, str), {}) 24607db96d56Sopenharmony_ci 24617db96d56Sopenharmony_ci def test_bad_slots(self): 24627db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24637db96d56Sopenharmony_ci type('A', (), {'__slots__': b'x'}) 24647db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24657db96d56Sopenharmony_ci type('A', (int,), {'__slots__': 'x'}) 24667db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24677db96d56Sopenharmony_ci type('A', (), {'__slots__': ''}) 24687db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24697db96d56Sopenharmony_ci type('A', (), {'__slots__': '42'}) 24707db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24717db96d56Sopenharmony_ci type('A', (), {'__slots__': 'x\x00y'}) 24727db96d56Sopenharmony_ci with self.assertRaises(ValueError): 24737db96d56Sopenharmony_ci type('A', (), {'__slots__': 'x', 'x': 0}) 24747db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24757db96d56Sopenharmony_ci type('A', (), {'__slots__': ('__dict__', '__dict__')}) 24767db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24777db96d56Sopenharmony_ci type('A', (), {'__slots__': ('__weakref__', '__weakref__')}) 24787db96d56Sopenharmony_ci 24797db96d56Sopenharmony_ci class B: 24807db96d56Sopenharmony_ci pass 24817db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24827db96d56Sopenharmony_ci type('A', (B,), {'__slots__': '__dict__'}) 24837db96d56Sopenharmony_ci with self.assertRaises(TypeError): 24847db96d56Sopenharmony_ci type('A', (B,), {'__slots__': '__weakref__'}) 24857db96d56Sopenharmony_ci 24867db96d56Sopenharmony_ci def test_namespace_order(self): 24877db96d56Sopenharmony_ci # bpo-34320: namespace should preserve order 24887db96d56Sopenharmony_ci od = collections.OrderedDict([('a', 1), ('b', 2)]) 24897db96d56Sopenharmony_ci od.move_to_end('a') 24907db96d56Sopenharmony_ci expected = list(od.items()) 24917db96d56Sopenharmony_ci 24927db96d56Sopenharmony_ci C = type('C', (), od) 24937db96d56Sopenharmony_ci self.assertEqual(list(C.__dict__.items())[:2], [('b', 2), ('a', 1)]) 24947db96d56Sopenharmony_ci 24957db96d56Sopenharmony_ci 24967db96d56Sopenharmony_cidef load_tests(loader, tests, pattern): 24977db96d56Sopenharmony_ci from doctest import DocTestSuite 24987db96d56Sopenharmony_ci tests.addTest(DocTestSuite(builtins)) 24997db96d56Sopenharmony_ci return tests 25007db96d56Sopenharmony_ci 25017db96d56Sopenharmony_ciif __name__ == "__main__": 25027db96d56Sopenharmony_ci unittest.main() 2503