PageRenderTime 93ms CodeModel.GetById 19ms RepoModel.GetById 0ms app.codeStats 0ms

/lib-python/modified-2.7/test/test_descr.py

https://bitbucket.org/dac_io/pypy
Python | 4677 lines | 4230 code | 269 blank | 178 comment | 272 complexity | 9cee9a9d8dd24ef7f42c0e2ea08755ca MD5 | raw file
  1. import __builtin__
  2. import sys
  3. import types
  4. import unittest
  5. import popen2 # trigger early the warning from popen2.py
  6. from copy import deepcopy
  7. from test import test_support
  8. class OperatorsTest(unittest.TestCase):
  9. def __init__(self, *args, **kwargs):
  10. unittest.TestCase.__init__(self, *args, **kwargs)
  11. self.binops = {
  12. 'add': '+',
  13. 'sub': '-',
  14. 'mul': '*',
  15. 'div': '/',
  16. 'divmod': 'divmod',
  17. 'pow': '**',
  18. 'lshift': '<<',
  19. 'rshift': '>>',
  20. 'and': '&',
  21. 'xor': '^',
  22. 'or': '|',
  23. 'cmp': 'cmp',
  24. 'lt': '<',
  25. 'le': '<=',
  26. 'eq': '==',
  27. 'ne': '!=',
  28. 'gt': '>',
  29. 'ge': '>=',
  30. }
  31. for name, expr in self.binops.items():
  32. if expr.islower():
  33. expr = expr + "(a, b)"
  34. else:
  35. expr = 'a %s b' % expr
  36. self.binops[name] = expr
  37. self.unops = {
  38. 'pos': '+',
  39. 'neg': '-',
  40. 'abs': 'abs',
  41. 'invert': '~',
  42. 'int': 'int',
  43. 'long': 'long',
  44. 'float': 'float',
  45. 'oct': 'oct',
  46. 'hex': 'hex',
  47. }
  48. for name, expr in self.unops.items():
  49. if expr.islower():
  50. expr = expr + "(a)"
  51. else:
  52. expr = '%s a' % expr
  53. self.unops[name] = expr
  54. def unop_test(self, a, res, expr="len(a)", meth="__len__"):
  55. d = {'a': a}
  56. self.assertEqual(eval(expr, d), res)
  57. t = type(a)
  58. m = getattr(t, meth)
  59. # Find method in parent class
  60. while meth not in t.__dict__:
  61. t = t.__bases__[0]
  62. # in some implementations (e.g. PyPy), 'm' can be a regular unbound
  63. # method object; the getattr() below obtains its underlying function.
  64. self.assertEqual(getattr(m, 'im_func', m), t.__dict__[meth])
  65. self.assertEqual(m(a), res)
  66. bm = getattr(a, meth)
  67. self.assertEqual(bm(), res)
  68. def binop_test(self, a, b, res, expr="a+b", meth="__add__"):
  69. d = {'a': a, 'b': b}
  70. # XXX Hack so this passes before 2.3 when -Qnew is specified.
  71. if meth == "__div__" and 1/2 == 0.5:
  72. meth = "__truediv__"
  73. if meth == '__divmod__': pass
  74. self.assertEqual(eval(expr, d), res)
  75. t = type(a)
  76. m = getattr(t, meth)
  77. while meth not in t.__dict__:
  78. t = t.__bases__[0]
  79. # in some implementations (e.g. PyPy), 'm' can be a regular unbound
  80. # method object; the getattr() below obtains its underlying function.
  81. self.assertEqual(getattr(m, 'im_func', m), t.__dict__[meth])
  82. self.assertEqual(m(a, b), res)
  83. bm = getattr(a, meth)
  84. self.assertEqual(bm(b), res)
  85. def ternop_test(self, a, b, c, res, expr="a[b:c]", meth="__getslice__"):
  86. d = {'a': a, 'b': b, 'c': c}
  87. self.assertEqual(eval(expr, d), res)
  88. t = type(a)
  89. m = getattr(t, meth)
  90. while meth not in t.__dict__:
  91. t = t.__bases__[0]
  92. # in some implementations (e.g. PyPy), 'm' can be a regular unbound
  93. # method object; the getattr() below obtains its underlying function.
  94. self.assertEqual(getattr(m, 'im_func', m), t.__dict__[meth])
  95. self.assertEqual(m(a, b, c), res)
  96. bm = getattr(a, meth)
  97. self.assertEqual(bm(b, c), res)
  98. def setop_test(self, a, b, res, stmt="a+=b", meth="__iadd__"):
  99. d = {'a': deepcopy(a), 'b': b}
  100. exec stmt in d
  101. self.assertEqual(d['a'], res)
  102. t = type(a)
  103. m = getattr(t, meth)
  104. while meth not in t.__dict__:
  105. t = t.__bases__[0]
  106. # in some implementations (e.g. PyPy), 'm' can be a regular unbound
  107. # method object; the getattr() below obtains its underlying function.
  108. self.assertEqual(getattr(m, 'im_func', m), t.__dict__[meth])
  109. d['a'] = deepcopy(a)
  110. m(d['a'], b)
  111. self.assertEqual(d['a'], res)
  112. d['a'] = deepcopy(a)
  113. bm = getattr(d['a'], meth)
  114. bm(b)
  115. self.assertEqual(d['a'], res)
  116. def set2op_test(self, a, b, c, res, stmt="a[b]=c", meth="__setitem__"):
  117. d = {'a': deepcopy(a), 'b': b, 'c': c}
  118. exec stmt in d
  119. self.assertEqual(d['a'], res)
  120. t = type(a)
  121. m = getattr(t, meth)
  122. while meth not in t.__dict__:
  123. t = t.__bases__[0]
  124. # in some implementations (e.g. PyPy), 'm' can be a regular unbound
  125. # method object; the getattr() below obtains its underlying function.
  126. self.assertEqual(getattr(m, 'im_func', m), t.__dict__[meth])
  127. d['a'] = deepcopy(a)
  128. m(d['a'], b, c)
  129. self.assertEqual(d['a'], res)
  130. d['a'] = deepcopy(a)
  131. bm = getattr(d['a'], meth)
  132. bm(b, c)
  133. self.assertEqual(d['a'], res)
  134. def set3op_test(self, a, b, c, d, res, stmt="a[b:c]=d", meth="__setslice__"):
  135. dictionary = {'a': deepcopy(a), 'b': b, 'c': c, 'd': d}
  136. exec stmt in dictionary
  137. self.assertEqual(dictionary['a'], res)
  138. t = type(a)
  139. while meth not in t.__dict__:
  140. t = t.__bases__[0]
  141. m = getattr(t, meth)
  142. # in some implementations (e.g. PyPy), 'm' can be a regular unbound
  143. # method object; the getattr() below obtains its underlying function.
  144. self.assertEqual(getattr(m, 'im_func', m), t.__dict__[meth])
  145. dictionary['a'] = deepcopy(a)
  146. m(dictionary['a'], b, c, d)
  147. self.assertEqual(dictionary['a'], res)
  148. dictionary['a'] = deepcopy(a)
  149. bm = getattr(dictionary['a'], meth)
  150. bm(b, c, d)
  151. self.assertEqual(dictionary['a'], res)
  152. def test_lists(self):
  153. # Testing list operations...
  154. # Asserts are within individual test methods
  155. self.binop_test([1], [2], [1,2], "a+b", "__add__")
  156. self.binop_test([1,2,3], 2, 1, "b in a", "__contains__")
  157. self.binop_test([1,2,3], 4, 0, "b in a", "__contains__")
  158. self.binop_test([1,2,3], 1, 2, "a[b]", "__getitem__")
  159. self.ternop_test([1,2,3], 0, 2, [1,2], "a[b:c]", "__getslice__")
  160. self.setop_test([1], [2], [1,2], "a+=b", "__iadd__")
  161. self.setop_test([1,2], 3, [1,2,1,2,1,2], "a*=b", "__imul__")
  162. self.unop_test([1,2,3], 3, "len(a)", "__len__")
  163. self.binop_test([1,2], 3, [1,2,1,2,1,2], "a*b", "__mul__")
  164. self.binop_test([1,2], 3, [1,2,1,2,1,2], "b*a", "__rmul__")
  165. self.set2op_test([1,2], 1, 3, [1,3], "a[b]=c", "__setitem__")
  166. self.set3op_test([1,2,3,4], 1, 3, [5,6], [1,5,6,4], "a[b:c]=d",
  167. "__setslice__")
  168. def test_dicts(self):
  169. # Testing dict operations...
  170. if hasattr(dict, '__cmp__'): # PyPy has only rich comparison on dicts
  171. self.binop_test({1:2}, {2:1}, -1, "cmp(a,b)", "__cmp__")
  172. else:
  173. self.binop_test({1:2}, {2:1}, True, "a < b", "__lt__")
  174. self.binop_test({1:2,3:4}, 1, 1, "b in a", "__contains__")
  175. self.binop_test({1:2,3:4}, 2, 0, "b in a", "__contains__")
  176. self.binop_test({1:2,3:4}, 1, 2, "a[b]", "__getitem__")
  177. d = {1:2, 3:4}
  178. l1 = []
  179. for i in d.keys():
  180. l1.append(i)
  181. l = []
  182. for i in iter(d):
  183. l.append(i)
  184. self.assertEqual(l, l1)
  185. l = []
  186. for i in d.__iter__():
  187. l.append(i)
  188. self.assertEqual(l, l1)
  189. l = []
  190. for i in dict.__iter__(d):
  191. l.append(i)
  192. self.assertEqual(l, l1)
  193. d = {1:2, 3:4}
  194. self.unop_test(d, 2, "len(a)", "__len__")
  195. self.assertEqual(eval(repr(d), {}), d)
  196. self.assertEqual(eval(d.__repr__(), {}), d)
  197. self.set2op_test({1:2,3:4}, 2, 3, {1:2,2:3,3:4}, "a[b]=c",
  198. "__setitem__")
  199. # Tests for unary and binary operators
  200. def number_operators(self, a, b, skip=[]):
  201. dict = {'a': a, 'b': b}
  202. for name, expr in self.binops.items():
  203. if name not in skip:
  204. name = "__%s__" % name
  205. if hasattr(a, name):
  206. res = eval(expr, dict)
  207. self.binop_test(a, b, res, expr, name)
  208. for name, expr in self.unops.items():
  209. if name not in skip:
  210. name = "__%s__" % name
  211. if hasattr(a, name):
  212. res = eval(expr, dict)
  213. self.unop_test(a, res, expr, name)
  214. def test_ints(self):
  215. # Testing int operations...
  216. self.number_operators(100, 3)
  217. # The following crashes in Python 2.2
  218. self.assertEqual((1).__nonzero__(), 1)
  219. self.assertEqual((0).__nonzero__(), 0)
  220. # This returns 'NotImplemented' in Python 2.2
  221. class C(int):
  222. def __add__(self, other):
  223. return NotImplemented
  224. self.assertEqual(C(5L), 5)
  225. try:
  226. C() + ""
  227. except TypeError:
  228. pass
  229. else:
  230. self.fail("NotImplemented should have caused TypeError")
  231. try:
  232. C(sys.maxint+1)
  233. except OverflowError:
  234. pass
  235. else:
  236. self.fail("should have raised OverflowError")
  237. def test_longs(self):
  238. # Testing long operations...
  239. self.number_operators(100L, 3L)
  240. def test_floats(self):
  241. # Testing float operations...
  242. self.number_operators(100.0, 3.0)
  243. def test_complexes(self):
  244. # Testing complex operations...
  245. self.number_operators(100.0j, 3.0j, skip=['lt', 'le', 'gt', 'ge',
  246. 'int', 'long', 'float'])
  247. class Number(complex):
  248. __slots__ = ['prec']
  249. def __new__(cls, *args, **kwds):
  250. result = complex.__new__(cls, *args)
  251. result.prec = kwds.get('prec', 12)
  252. return result
  253. def __repr__(self):
  254. prec = self.prec
  255. if self.imag == 0.0:
  256. return "%.*g" % (prec, self.real)
  257. if self.real == 0.0:
  258. return "%.*gj" % (prec, self.imag)
  259. return "(%.*g+%.*gj)" % (prec, self.real, prec, self.imag)
  260. __str__ = __repr__
  261. a = Number(3.14, prec=6)
  262. self.assertEqual(repr(a), "3.14")
  263. self.assertEqual(a.prec, 6)
  264. a = Number(a, prec=2)
  265. self.assertEqual(repr(a), "3.1")
  266. self.assertEqual(a.prec, 2)
  267. a = Number(234.5)
  268. self.assertEqual(repr(a), "234.5")
  269. self.assertEqual(a.prec, 12)
  270. @test_support.impl_detail("the module 'xxsubtype' is internal")
  271. def test_spam_lists(self):
  272. # Testing spamlist operations...
  273. import copy, xxsubtype as spam
  274. def spamlist(l, memo=None):
  275. import xxsubtype as spam
  276. return spam.spamlist(l)
  277. # This is an ugly hack:
  278. copy._deepcopy_dispatch[spam.spamlist] = spamlist
  279. self.binop_test(spamlist([1]), spamlist([2]), spamlist([1,2]), "a+b",
  280. "__add__")
  281. self.binop_test(spamlist([1,2,3]), 2, 1, "b in a", "__contains__")
  282. self.binop_test(spamlist([1,2,3]), 4, 0, "b in a", "__contains__")
  283. self.binop_test(spamlist([1,2,3]), 1, 2, "a[b]", "__getitem__")
  284. self.ternop_test(spamlist([1,2,3]), 0, 2, spamlist([1,2]), "a[b:c]",
  285. "__getslice__")
  286. self.setop_test(spamlist([1]), spamlist([2]), spamlist([1,2]), "a+=b",
  287. "__iadd__")
  288. self.setop_test(spamlist([1,2]), 3, spamlist([1,2,1,2,1,2]), "a*=b",
  289. "__imul__")
  290. self.unop_test(spamlist([1,2,3]), 3, "len(a)", "__len__")
  291. self.binop_test(spamlist([1,2]), 3, spamlist([1,2,1,2,1,2]), "a*b",
  292. "__mul__")
  293. self.binop_test(spamlist([1,2]), 3, spamlist([1,2,1,2,1,2]), "b*a",
  294. "__rmul__")
  295. self.set2op_test(spamlist([1,2]), 1, 3, spamlist([1,3]), "a[b]=c",
  296. "__setitem__")
  297. self.set3op_test(spamlist([1,2,3,4]), 1, 3, spamlist([5,6]),
  298. spamlist([1,5,6,4]), "a[b:c]=d", "__setslice__")
  299. # Test subclassing
  300. class C(spam.spamlist):
  301. def foo(self): return 1
  302. a = C()
  303. self.assertEqual(a, [])
  304. self.assertEqual(a.foo(), 1)
  305. a.append(100)
  306. self.assertEqual(a, [100])
  307. self.assertEqual(a.getstate(), 0)
  308. a.setstate(42)
  309. self.assertEqual(a.getstate(), 42)
  310. @test_support.impl_detail("the module 'xxsubtype' is internal")
  311. def test_spam_dicts(self):
  312. # Testing spamdict operations...
  313. import copy, xxsubtype as spam
  314. def spamdict(d, memo=None):
  315. import xxsubtype as spam
  316. sd = spam.spamdict()
  317. for k, v in d.items():
  318. sd[k] = v
  319. return sd
  320. # This is an ugly hack:
  321. copy._deepcopy_dispatch[spam.spamdict] = spamdict
  322. self.binop_test(spamdict({1:2}), spamdict({2:1}), -1, "cmp(a,b)",
  323. "__cmp__")
  324. self.binop_test(spamdict({1:2,3:4}), 1, 1, "b in a", "__contains__")
  325. self.binop_test(spamdict({1:2,3:4}), 2, 0, "b in a", "__contains__")
  326. self.binop_test(spamdict({1:2,3:4}), 1, 2, "a[b]", "__getitem__")
  327. d = spamdict({1:2,3:4})
  328. l1 = []
  329. for i in d.keys():
  330. l1.append(i)
  331. l = []
  332. for i in iter(d):
  333. l.append(i)
  334. self.assertEqual(l, l1)
  335. l = []
  336. for i in d.__iter__():
  337. l.append(i)
  338. self.assertEqual(l, l1)
  339. l = []
  340. for i in type(spamdict({})).__iter__(d):
  341. l.append(i)
  342. self.assertEqual(l, l1)
  343. straightd = {1:2, 3:4}
  344. spamd = spamdict(straightd)
  345. self.unop_test(spamd, 2, "len(a)", "__len__")
  346. self.unop_test(spamd, repr(straightd), "repr(a)", "__repr__")
  347. self.set2op_test(spamdict({1:2,3:4}), 2, 3, spamdict({1:2,2:3,3:4}),
  348. "a[b]=c", "__setitem__")
  349. # Test subclassing
  350. class C(spam.spamdict):
  351. def foo(self): return 1
  352. a = C()
  353. self.assertEqual(a.items(), [])
  354. self.assertEqual(a.foo(), 1)
  355. a['foo'] = 'bar'
  356. self.assertEqual(a.items(), [('foo', 'bar')])
  357. self.assertEqual(a.getstate(), 0)
  358. a.setstate(100)
  359. self.assertEqual(a.getstate(), 100)
  360. class ClassPropertiesAndMethods(unittest.TestCase):
  361. def test_python_dicts(self):
  362. # Testing Python subclass of dict...
  363. self.assertTrue(issubclass(dict, dict))
  364. self.assertIsInstance({}, dict)
  365. d = dict()
  366. self.assertEqual(d, {})
  367. self.assertTrue(d.__class__ is dict)
  368. self.assertIsInstance(d, dict)
  369. class C(dict):
  370. state = -1
  371. def __init__(self_local, *a, **kw):
  372. if a:
  373. self.assertEqual(len(a), 1)
  374. self_local.state = a[0]
  375. if kw:
  376. for k, v in kw.items():
  377. self_local[v] = k
  378. def __getitem__(self, key):
  379. return self.get(key, 0)
  380. def __setitem__(self_local, key, value):
  381. self.assertIsInstance(key, type(0))
  382. dict.__setitem__(self_local, key, value)
  383. def setstate(self, state):
  384. self.state = state
  385. def getstate(self):
  386. return self.state
  387. self.assertTrue(issubclass(C, dict))
  388. a1 = C(12)
  389. self.assertEqual(a1.state, 12)
  390. a2 = C(foo=1, bar=2)
  391. self.assertEqual(a2[1] == 'foo' and a2[2], 'bar')
  392. a = C()
  393. self.assertEqual(a.state, -1)
  394. self.assertEqual(a.getstate(), -1)
  395. a.setstate(0)
  396. self.assertEqual(a.state, 0)
  397. self.assertEqual(a.getstate(), 0)
  398. a.setstate(10)
  399. self.assertEqual(a.state, 10)
  400. self.assertEqual(a.getstate(), 10)
  401. self.assertEqual(a[42], 0)
  402. a[42] = 24
  403. self.assertEqual(a[42], 24)
  404. N = 50
  405. for i in range(N):
  406. a[i] = C()
  407. for j in range(N):
  408. a[i][j] = i*j
  409. for i in range(N):
  410. for j in range(N):
  411. self.assertEqual(a[i][j], i*j)
  412. def test_python_lists(self):
  413. # Testing Python subclass of list...
  414. class C(list):
  415. def __getitem__(self, i):
  416. return list.__getitem__(self, i) + 100
  417. def __getslice__(self, i, j):
  418. return (i, j)
  419. a = C()
  420. a.extend([0,1,2])
  421. self.assertEqual(a[0], 100)
  422. self.assertEqual(a[1], 101)
  423. self.assertEqual(a[2], 102)
  424. self.assertEqual(a[100:200], (100,200))
  425. def test_metaclass(self):
  426. # Testing __metaclass__...
  427. class C:
  428. __metaclass__ = type
  429. def __init__(self):
  430. self.__state = 0
  431. def getstate(self):
  432. return self.__state
  433. def setstate(self, state):
  434. self.__state = state
  435. a = C()
  436. self.assertEqual(a.getstate(), 0)
  437. a.setstate(10)
  438. self.assertEqual(a.getstate(), 10)
  439. class D:
  440. class __metaclass__(type):
  441. def myself(cls): return cls
  442. self.assertEqual(D.myself(), D)
  443. d = D()
  444. self.assertEqual(d.__class__, D)
  445. class M1(type):
  446. def __new__(cls, name, bases, dict):
  447. dict['__spam__'] = 1
  448. return type.__new__(cls, name, bases, dict)
  449. class C:
  450. __metaclass__ = M1
  451. self.assertEqual(C.__spam__, 1)
  452. c = C()
  453. self.assertEqual(c.__spam__, 1)
  454. class _instance(object):
  455. pass
  456. class M2(object):
  457. @staticmethod
  458. def __new__(cls, name, bases, dict):
  459. self = object.__new__(cls)
  460. self.name = name
  461. self.bases = bases
  462. self.dict = dict
  463. return self
  464. def __call__(self):
  465. it = _instance()
  466. # Early binding of methods
  467. for key in self.dict:
  468. if key.startswith("__"):
  469. continue
  470. setattr(it, key, self.dict[key].__get__(it, self))
  471. return it
  472. class C:
  473. __metaclass__ = M2
  474. def spam(self):
  475. return 42
  476. self.assertEqual(C.name, 'C')
  477. self.assertEqual(C.bases, ())
  478. self.assertIn('spam', C.dict)
  479. c = C()
  480. self.assertEqual(c.spam(), 42)
  481. # More metaclass examples
  482. class autosuper(type):
  483. # Automatically add __super to the class
  484. # This trick only works for dynamic classes
  485. def __new__(metaclass, name, bases, dict):
  486. cls = super(autosuper, metaclass).__new__(metaclass,
  487. name, bases, dict)
  488. # Name mangling for __super removes leading underscores
  489. while name[:1] == "_":
  490. name = name[1:]
  491. if name:
  492. name = "_%s__super" % name
  493. else:
  494. name = "__super"
  495. setattr(cls, name, super(cls))
  496. return cls
  497. class A:
  498. __metaclass__ = autosuper
  499. def meth(self):
  500. return "A"
  501. class B(A):
  502. def meth(self):
  503. return "B" + self.__super.meth()
  504. class C(A):
  505. def meth(self):
  506. return "C" + self.__super.meth()
  507. class D(C, B):
  508. def meth(self):
  509. return "D" + self.__super.meth()
  510. self.assertEqual(D().meth(), "DCBA")
  511. class E(B, C):
  512. def meth(self):
  513. return "E" + self.__super.meth()
  514. self.assertEqual(E().meth(), "EBCA")
  515. class autoproperty(type):
  516. # Automatically create property attributes when methods
  517. # named _get_x and/or _set_x are found
  518. def __new__(metaclass, name, bases, dict):
  519. hits = {}
  520. for key, val in dict.iteritems():
  521. if key.startswith("_get_"):
  522. key = key[5:]
  523. get, set = hits.get(key, (None, None))
  524. get = val
  525. hits[key] = get, set
  526. elif key.startswith("_set_"):
  527. key = key[5:]
  528. get, set = hits.get(key, (None, None))
  529. set = val
  530. hits[key] = get, set
  531. for key, (get, set) in hits.iteritems():
  532. dict[key] = property(get, set)
  533. return super(autoproperty, metaclass).__new__(metaclass,
  534. name, bases, dict)
  535. class A:
  536. __metaclass__ = autoproperty
  537. def _get_x(self):
  538. return -self.__x
  539. def _set_x(self, x):
  540. self.__x = -x
  541. a = A()
  542. self.assertTrue(not hasattr(a, "x"))
  543. a.x = 12
  544. self.assertEqual(a.x, 12)
  545. self.assertEqual(a._A__x, -12)
  546. class multimetaclass(autoproperty, autosuper):
  547. # Merge of multiple cooperating metaclasses
  548. pass
  549. class A:
  550. __metaclass__ = multimetaclass
  551. def _get_x(self):
  552. return "A"
  553. class B(A):
  554. def _get_x(self):
  555. return "B" + self.__super._get_x()
  556. class C(A):
  557. def _get_x(self):
  558. return "C" + self.__super._get_x()
  559. class D(C, B):
  560. def _get_x(self):
  561. return "D" + self.__super._get_x()
  562. self.assertEqual(D().x, "DCBA")
  563. # Make sure type(x) doesn't call x.__class__.__init__
  564. class T(type):
  565. counter = 0
  566. def __init__(self, *args):
  567. T.counter += 1
  568. class C:
  569. __metaclass__ = T
  570. self.assertEqual(T.counter, 1)
  571. a = C()
  572. self.assertEqual(type(a), C)
  573. self.assertEqual(T.counter, 1)
  574. class C(object): pass
  575. c = C()
  576. try: c()
  577. except TypeError: pass
  578. else: self.fail("calling object w/o call method should raise "
  579. "TypeError")
  580. # Testing code to find most derived baseclass
  581. class A(type):
  582. def __new__(*args, **kwargs):
  583. return type.__new__(*args, **kwargs)
  584. class B(object):
  585. pass
  586. class C(object):
  587. __metaclass__ = A
  588. # The most derived metaclass of D is A rather than type.
  589. class D(B, C):
  590. pass
  591. def test_module_subclasses(self):
  592. # Testing Python subclass of module...
  593. log = []
  594. MT = type(sys)
  595. class MM(MT):
  596. def __init__(self, name):
  597. MT.__init__(self, name)
  598. def __getattribute__(self, name):
  599. log.append(("getattr", name))
  600. return MT.__getattribute__(self, name)
  601. def __setattr__(self, name, value):
  602. log.append(("setattr", name, value))
  603. MT.__setattr__(self, name, value)
  604. def __delattr__(self, name):
  605. log.append(("delattr", name))
  606. MT.__delattr__(self, name)
  607. a = MM("a")
  608. a.foo = 12
  609. x = a.foo
  610. del a.foo
  611. self.assertEqual(log, [("setattr", "foo", 12),
  612. ("getattr", "foo"),
  613. ("delattr", "foo")])
  614. # http://python.org/sf/1174712
  615. try:
  616. class Module(types.ModuleType, str):
  617. pass
  618. except TypeError:
  619. pass
  620. else:
  621. self.fail("inheriting from ModuleType and str at the same time "
  622. "should fail")
  623. def test_multiple_inheritence(self):
  624. # Testing multiple inheritance...
  625. class C(object):
  626. def __init__(self):
  627. self.__state = 0
  628. def getstate(self):
  629. return self.__state
  630. def setstate(self, state):
  631. self.__state = state
  632. a = C()
  633. self.assertEqual(a.getstate(), 0)
  634. a.setstate(10)
  635. self.assertEqual(a.getstate(), 10)
  636. class D(dict, C):
  637. def __init__(self):
  638. type({}).__init__(self)
  639. C.__init__(self)
  640. d = D()
  641. self.assertEqual(d.keys(), [])
  642. d["hello"] = "world"
  643. self.assertEqual(d.items(), [("hello", "world")])
  644. self.assertEqual(d["hello"], "world")
  645. self.assertEqual(d.getstate(), 0)
  646. d.setstate(10)
  647. self.assertEqual(d.getstate(), 10)
  648. self.assertEqual(D.__mro__, (D, dict, C, object))
  649. # SF bug #442833
  650. class Node(object):
  651. def __int__(self):
  652. return int(self.foo())
  653. def foo(self):
  654. return "23"
  655. class Frag(Node, list):
  656. def foo(self):
  657. return "42"
  658. self.assertEqual(Node().__int__(), 23)
  659. self.assertEqual(int(Node()), 23)
  660. self.assertEqual(Frag().__int__(), 42)
  661. self.assertEqual(int(Frag()), 42)
  662. # MI mixing classic and new-style classes.
  663. class A:
  664. x = 1
  665. class B(A):
  666. pass
  667. class C(A):
  668. x = 2
  669. class D(B, C):
  670. pass
  671. self.assertEqual(D.x, 1)
  672. # Classic MRO is preserved for a classic base class.
  673. class E(D, object):
  674. pass
  675. self.assertEqual(E.__mro__, (E, D, B, A, C, object))
  676. self.assertEqual(E.x, 1)
  677. # But with a mix of classic bases, their MROs are combined using
  678. # new-style MRO.
  679. class F(B, C, object):
  680. pass
  681. self.assertEqual(F.__mro__, (F, B, C, A, object))
  682. self.assertEqual(F.x, 2)
  683. # Try something else.
  684. class C:
  685. def cmethod(self):
  686. return "C a"
  687. def all_method(self):
  688. return "C b"
  689. class M1(C, object):
  690. def m1method(self):
  691. return "M1 a"
  692. def all_method(self):
  693. return "M1 b"
  694. self.assertEqual(M1.__mro__, (M1, C, object))
  695. m = M1()
  696. self.assertEqual(m.cmethod(), "C a")
  697. self.assertEqual(m.m1method(), "M1 a")
  698. self.assertEqual(m.all_method(), "M1 b")
  699. class D(C):
  700. def dmethod(self):
  701. return "D a"
  702. def all_method(self):
  703. return "D b"
  704. class M2(D, object):
  705. def m2method(self):
  706. return "M2 a"
  707. def all_method(self):
  708. return "M2 b"
  709. self.assertEqual(M2.__mro__, (M2, D, C, object))
  710. m = M2()
  711. self.assertEqual(m.cmethod(), "C a")
  712. self.assertEqual(m.dmethod(), "D a")
  713. self.assertEqual(m.m2method(), "M2 a")
  714. self.assertEqual(m.all_method(), "M2 b")
  715. class M3(M1, M2, object):
  716. def m3method(self):
  717. return "M3 a"
  718. def all_method(self):
  719. return "M3 b"
  720. self.assertEqual(M3.__mro__, (M3, M1, M2, D, C, object))
  721. m = M3()
  722. self.assertEqual(m.cmethod(), "C a")
  723. self.assertEqual(m.dmethod(), "D a")
  724. self.assertEqual(m.m1method(), "M1 a")
  725. self.assertEqual(m.m2method(), "M2 a")
  726. self.assertEqual(m.m3method(), "M3 a")
  727. self.assertEqual(m.all_method(), "M3 b")
  728. class Classic:
  729. pass
  730. try:
  731. class New(Classic):
  732. __metaclass__ = type
  733. except TypeError:
  734. pass
  735. else:
  736. self.fail("new class with only classic bases - shouldn't be")
  737. def test_diamond_inheritence(self):
  738. # Testing multiple inheritance special cases...
  739. class A(object):
  740. def spam(self): return "A"
  741. self.assertEqual(A().spam(), "A")
  742. class B(A):
  743. def boo(self): return "B"
  744. def spam(self): return "B"
  745. self.assertEqual(B().spam(), "B")
  746. self.assertEqual(B().boo(), "B")
  747. class C(A):
  748. def boo(self): return "C"
  749. self.assertEqual(C().spam(), "A")
  750. self.assertEqual(C().boo(), "C")
  751. class D(B, C): pass
  752. self.assertEqual(D().spam(), "B")
  753. self.assertEqual(D().boo(), "B")
  754. self.assertEqual(D.__mro__, (D, B, C, A, object))
  755. class E(C, B): pass
  756. self.assertEqual(E().spam(), "B")
  757. self.assertEqual(E().boo(), "C")
  758. self.assertEqual(E.__mro__, (E, C, B, A, object))
  759. # MRO order disagreement
  760. try:
  761. class F(D, E): pass
  762. except TypeError:
  763. pass
  764. else:
  765. self.fail("expected MRO order disagreement (F)")
  766. try:
  767. class G(E, D): pass
  768. except TypeError:
  769. pass
  770. else:
  771. self.fail("expected MRO order disagreement (G)")
  772. # see thread python-dev/2002-October/029035.html
  773. def test_ex5_from_c3_switch(self):
  774. # Testing ex5 from C3 switch discussion...
  775. class A(object): pass
  776. class B(object): pass
  777. class C(object): pass
  778. class X(A): pass
  779. class Y(A): pass
  780. class Z(X,B,Y,C): pass
  781. self.assertEqual(Z.__mro__, (Z, X, B, Y, A, C, object))
  782. # see "A Monotonic Superclass Linearization for Dylan",
  783. # by Kim Barrett et al. (OOPSLA 1996)
  784. def test_monotonicity(self):
  785. # Testing MRO monotonicity...
  786. class Boat(object): pass
  787. class DayBoat(Boat): pass
  788. class WheelBoat(Boat): pass
  789. class EngineLess(DayBoat): pass
  790. class SmallMultihull(DayBoat): pass
  791. class PedalWheelBoat(EngineLess,WheelBoat): pass
  792. class SmallCatamaran(SmallMultihull): pass
  793. class Pedalo(PedalWheelBoat,SmallCatamaran): pass
  794. self.assertEqual(PedalWheelBoat.__mro__,
  795. (PedalWheelBoat, EngineLess, DayBoat, WheelBoat, Boat, object))
  796. self.assertEqual(SmallCatamaran.__mro__,
  797. (SmallCatamaran, SmallMultihull, DayBoat, Boat, object))
  798. self.assertEqual(Pedalo.__mro__,
  799. (Pedalo, PedalWheelBoat, EngineLess, SmallCatamaran,
  800. SmallMultihull, DayBoat, WheelBoat, Boat, object))
  801. # see "A Monotonic Superclass Linearization for Dylan",
  802. # by Kim Barrett et al. (OOPSLA 1996)
  803. def test_consistency_with_epg(self):
  804. # Testing consistency with EPG...
  805. class Pane(object): pass
  806. class ScrollingMixin(object): pass
  807. class EditingMixin(object): pass
  808. class ScrollablePane(Pane,ScrollingMixin): pass
  809. class EditablePane(Pane,EditingMixin): pass
  810. class EditableScrollablePane(ScrollablePane,EditablePane): pass
  811. self.assertEqual(EditableScrollablePane.__mro__,
  812. (EditableScrollablePane, ScrollablePane, EditablePane, Pane,
  813. ScrollingMixin, EditingMixin, object))
  814. def test_mro_disagreement(self):
  815. # Testing error messages for MRO disagreement...
  816. mro_err_msg = """Cannot create a consistent method resolution
  817. order (MRO) for bases """
  818. def raises(exc, expected, callable, *args):
  819. try:
  820. callable(*args)
  821. except exc, msg:
  822. # the exact msg is generally considered an impl detail
  823. if test_support.check_impl_detail():
  824. if not str(msg).startswith(expected):
  825. self.fail("Message %r, expected %r" %
  826. (str(msg), expected))
  827. else:
  828. self.fail("Expected %s" % exc)
  829. class A(object): pass
  830. class B(A): pass
  831. class C(object): pass
  832. # Test some very simple errors
  833. raises(TypeError, "duplicate base class A",
  834. type, "X", (A, A), {})
  835. raises(TypeError, mro_err_msg,
  836. type, "X", (A, B), {})
  837. raises(TypeError, mro_err_msg,
  838. type, "X", (A, C, B), {})
  839. # Test a slightly more complex error
  840. class GridLayout(object): pass
  841. class HorizontalGrid(GridLayout): pass
  842. class VerticalGrid(GridLayout): pass
  843. class HVGrid(HorizontalGrid, VerticalGrid): pass
  844. class VHGrid(VerticalGrid, HorizontalGrid): pass
  845. raises(TypeError, mro_err_msg,
  846. type, "ConfusedGrid", (HVGrid, VHGrid), {})
  847. def test_object_class(self):
  848. # Testing object class...
  849. a = object()
  850. self.assertEqual(a.__class__, object)
  851. self.assertEqual(type(a), object)
  852. b = object()
  853. self.assertNotEqual(a, b)
  854. self.assertFalse(hasattr(a, "foo"))
  855. try:
  856. a.foo = 12
  857. except (AttributeError, TypeError):
  858. pass
  859. else:
  860. self.fail("object() should not allow setting a foo attribute")
  861. self.assertFalse(hasattr(object(), "__dict__"))
  862. class Cdict(object):
  863. pass
  864. x = Cdict()
  865. self.assertEqual(x.__dict__, {})
  866. x.foo = 1
  867. self.assertEqual(x.foo, 1)
  868. self.assertEqual(x.__dict__, {'foo': 1})
  869. def test_slots(self):
  870. # Testing __slots__...
  871. class C0(object):
  872. __slots__ = []
  873. x = C0()
  874. self.assertFalse(hasattr(x, "__dict__"))
  875. self.assertFalse(hasattr(x, "foo"))
  876. class C1(object):
  877. __slots__ = ['a']
  878. x = C1()
  879. self.assertFalse(hasattr(x, "__dict__"))
  880. self.assertFalse(hasattr(x, "a"))
  881. x.a = 1
  882. self.assertEqual(x.a, 1)
  883. x.a = None
  884. self.assertEqual(x.a, None)
  885. del x.a
  886. self.assertFalse(hasattr(x, "a"))
  887. class C3(object):
  888. __slots__ = ['a', 'b', 'c']
  889. x = C3()
  890. self.assertFalse(hasattr(x, "__dict__"))
  891. self.assertFalse(hasattr(x, 'a'))
  892. self.assertFalse(hasattr(x, 'b'))
  893. self.assertFalse(hasattr(x, 'c'))
  894. x.a = 1
  895. x.b = 2
  896. x.c = 3
  897. self.assertEqual(x.a, 1)
  898. self.assertEqual(x.b, 2)
  899. self.assertEqual(x.c, 3)
  900. class C4(object):
  901. """Validate name mangling"""
  902. __slots__ = ['__a']
  903. def __init__(self, value):
  904. self.__a = value
  905. def get(self):
  906. return self.__a
  907. x = C4(5)
  908. self.assertFalse(hasattr(x, '__dict__'))
  909. self.assertFalse(hasattr(x, '__a'))
  910. self.assertEqual(x.get(), 5)
  911. try:
  912. x.__a = 6
  913. except AttributeError:
  914. pass
  915. else:
  916. self.fail("Double underscored names not mangled")
  917. # Make sure slot names are proper identifiers
  918. try:
  919. class C(object):
  920. __slots__ = [None]
  921. except TypeError:
  922. pass
  923. else:
  924. self.fail("[None] slots not caught")
  925. try:
  926. class C(object):
  927. __slots__ = ["foo bar"]
  928. except TypeError:
  929. pass
  930. else:
  931. self.fail("['foo bar'] slots not caught")
  932. try:
  933. class C(object):
  934. __slots__ = ["foo\0bar"]
  935. except TypeError:
  936. pass
  937. else:
  938. self.fail("['foo\\0bar'] slots not caught")
  939. try:
  940. class C(object):
  941. __slots__ = ["1"]
  942. except TypeError:
  943. pass
  944. else:
  945. self.fail("['1'] slots not caught")
  946. try:
  947. class C(object):
  948. __slots__ = [""]
  949. except TypeError:
  950. pass
  951. else:
  952. self.fail("[''] slots not caught")
  953. class C(object):
  954. __slots__ = ["a", "a_b", "_a", "A0123456789Z"]
  955. # XXX(nnorwitz): was there supposed to be something tested
  956. # from the class above?
  957. # Test a single string is not expanded as a sequence.
  958. class C(object):
  959. __slots__ = "abc"
  960. c = C()
  961. c.abc = 5
  962. self.assertEqual(c.abc, 5)
  963. # Test unicode slot names
  964. try:
  965. unicode
  966. except NameError:
  967. pass
  968. else:
  969. # Test a single unicode string is not expanded as a sequence.
  970. class C(object):
  971. __slots__ = unicode("abc")
  972. c = C()
  973. c.abc = 5
  974. self.assertEqual(c.abc, 5)
  975. # _unicode_to_string used to modify slots in certain circumstances
  976. slots = (unicode("foo"), unicode("bar"))
  977. class C(object):
  978. __slots__ = slots
  979. x = C()
  980. x.foo = 5
  981. self.assertEqual(x.foo, 5)
  982. self.assertEqual(type(slots[0]), unicode)
  983. # this used to leak references
  984. try:
  985. class C(object):
  986. __slots__ = [unichr(128)]
  987. except (TypeError, UnicodeEncodeError):
  988. pass
  989. else:
  990. self.fail("[unichr(128)] slots not caught")
  991. # Test leaks
  992. class Counted(object):
  993. counter = 0 # counts the number of instances alive
  994. def __init__(self):
  995. Counted.counter += 1
  996. def __del__(self):
  997. Counted.counter -= 1
  998. class C(object):
  999. __slots__ = ['a', 'b', 'c']
  1000. x = C()
  1001. x.a = Counted()
  1002. x.b = Counted()
  1003. x.c = Counted()
  1004. self.assertEqual(Counted.counter, 3)
  1005. del x
  1006. test_support.gc_collect()
  1007. self.assertEqual(Counted.counter, 0)
  1008. class D(C):
  1009. pass
  1010. x = D()
  1011. x.a = Counted()
  1012. x.z = Counted()
  1013. self.assertEqual(Counted.counter, 2)
  1014. del x
  1015. test_support.gc_collect()
  1016. self.assertEqual(Counted.counter, 0)
  1017. class E(D):
  1018. __slots__ = ['e']
  1019. x = E()
  1020. x.a = Counted()
  1021. x.z = Counted()
  1022. x.e = Counted()
  1023. self.assertEqual(Counted.counter, 3)
  1024. del x
  1025. test_support.gc_collect()
  1026. self.assertEqual(Counted.counter, 0)
  1027. # Test cyclical leaks [SF bug 519621]
  1028. class F(object):
  1029. __slots__ = ['a', 'b']
  1030. s = F()
  1031. s.a = [Counted(), s]
  1032. self.assertEqual(Counted.counter, 1)
  1033. s = None
  1034. test_support.gc_collect()
  1035. self.assertEqual(Counted.counter, 0)
  1036. # Test lookup leaks [SF bug 572567]
  1037. import gc
  1038. if test_support.check_impl_detail():
  1039. class G(object):
  1040. def __cmp__(self, other):
  1041. return 0
  1042. __hash__ = None # Silence Py3k warning
  1043. g = G()
  1044. orig_objects = len(gc.get_objects())
  1045. for i in xrange(10):
  1046. g==g
  1047. new_objects = len(gc.get_objects())
  1048. self.assertEqual(orig_objects, new_objects)
  1049. class H(object):
  1050. __slots__ = ['a', 'b']
  1051. def __init__(self):
  1052. self.a = 1
  1053. self.b = 2
  1054. def __del__(self_):
  1055. self.assertEqual(self_.a, 1)
  1056. self.assertEqual(self_.b, 2)
  1057. with test_support.captured_output('stderr') as s:
  1058. h = H()
  1059. del h
  1060. self.assertEqual(s.getvalue(), '')
  1061. class X(object):
  1062. __slots__ = "a"
  1063. with self.assertRaises(AttributeError):
  1064. del X().a
  1065. def test_slots_special(self):
  1066. # Testing __dict__ and __weakref__ in __slots__...
  1067. class D(object):
  1068. __slots__ = ["__dict__"]
  1069. a = D()
  1070. self.assertTrue(hasattr(a, "__dict__"))
  1071. self.assertFalse(hasattr(a, "__weakref__"))
  1072. a.foo = 42
  1073. self.assertEqual(a.__dict__, {"foo": 42})
  1074. class W(object):
  1075. __slots__ = ["__weakref__"]
  1076. a = W()
  1077. self.assertTrue(hasattr(a, "__weakref__"))
  1078. self.assertFalse(hasattr(a, "__dict__"))
  1079. try:
  1080. a.foo = 42
  1081. except AttributeError:
  1082. pass
  1083. else:
  1084. self.fail("shouldn't be allowed to set a.foo")
  1085. class C1(W, D):
  1086. __slots__ = []
  1087. a = C1()
  1088. self.assertTrue(hasattr(a, "__dict__"))
  1089. self.assertTrue(hasattr(a, "__weakref__"))
  1090. a.foo = 42
  1091. self.assertEqual(a.__dict__, {"foo": 42})
  1092. class C2(D, W):
  1093. __slots__ = []
  1094. a = C2()
  1095. self.assertTrue(hasattr(a, "__dict__"))
  1096. self.assertTrue(hasattr(a, "__weakref__"))
  1097. a.foo = 42
  1098. self.assertEqual(a.__dict__, {"foo": 42})
  1099. def test_slots_descriptor(self):
  1100. # Issue2115: slot descriptors did not correctly check
  1101. # the type of the given object
  1102. import abc
  1103. class MyABC:
  1104. __metaclass__ = abc.ABCMeta
  1105. __slots__ = "a"
  1106. class Unrelated(object):
  1107. pass
  1108. MyABC.register(Unrelated)
  1109. u = Unrelated()
  1110. self.assertIsInstance(u, MyABC)
  1111. # This used to crash
  1112. self.assertRaises(TypeError, MyABC.a.__set__, u, 3)
  1113. def test_metaclass_cmp(self):
  1114. # See bug 7491.
  1115. class M(type):
  1116. def __cmp__(self, other):
  1117. return -1
  1118. class X(object):
  1119. __metaclass__ = M
  1120. self.assertTrue(X < M)
  1121. def test_dynamics(self):
  1122. # Testing class attribute propagation...
  1123. class D(object):
  1124. pass
  1125. class E(D):
  1126. pass
  1127. class F(D):
  1128. pass
  1129. D.foo = 1
  1130. self.assertEqual(D.foo, 1)
  1131. # Test that dynamic attributes are inherited
  1132. self.assertEqual(E.foo, 1)
  1133. self.assertEqual(F.foo, 1)
  1134. # Test dynamic instances
  1135. class C(object):
  1136. pass
  1137. a = C()
  1138. self.assertFalse(hasattr(a, "foobar"))
  1139. C.foobar = 2
  1140. self.assertEqual(a.foobar, 2)
  1141. C.method = lambda self: 42
  1142. self.assertEqual(a.method(), 42)
  1143. C.__repr__ = lambda self: "C()"
  1144. self.assertEqual(repr(a), "C()")
  1145. C.__int__ = lambda self: 100
  1146. self.assertEqual(int(a), 100)
  1147. self.assertEqual(a.foobar, 2)
  1148. self.assertFalse(hasattr(a, "spam"))
  1149. def mygetattr(self, name):
  1150. if name == "spam":
  1151. return "spam"
  1152. raise AttributeError
  1153. C.__getattr__ = mygetattr
  1154. self.assertEqual(a.spam, "spam")
  1155. a.new = 12
  1156. self.assertEqual(a.new, 12)
  1157. def mysetattr(self, name, value):
  1158. if name == "spam":
  1159. raise AttributeError
  1160. return object.__setattr__(self, name, value)
  1161. C.__setattr__ = mysetattr
  1162. try:
  1163. a.spam = "not spam"
  1164. except AttributeError:
  1165. pass
  1166. else:
  1167. self.fail("expected AttributeError")
  1168. self.assertEqual(a.spam, "spam")
  1169. class D(C):
  1170. pass
  1171. d = D()
  1172. d.foo = 1
  1173. self.assertEqual(d.foo, 1)
  1174. # Test handling of int*seq and seq*int
  1175. class I(int):
  1176. pass
  1177. self.assertEqual("a"*I(2), "aa")
  1178. self.assertEqual(I(2)*"a", "aa")
  1179. self.assertEqual(2*I(3), 6)
  1180. self.assertEqual(I(3)*2, 6)
  1181. self.assertEqual(I(3)*I(2), 6)
  1182. # Test handling of long*seq and seq*long
  1183. class L(long):
  1184. pass
  1185. self.assertEqual("a"*L(2L), "aa")
  1186. self.assertEqual(L(2L)*"a", "aa")
  1187. self.assertEqual(2*L(3), 6)
  1188. self.assertEqual(L(3)*2, 6)
  1189. self.assertEqual(L(3)*L(2), 6)
  1190. # Test comparison of classes with dynamic metaclasses
  1191. class dynamicmetaclass(type):
  1192. pass
  1193. class someclass:
  1194. __metaclass__ = dynamicmetaclass
  1195. self.assertNotEqual(someclass, object)
  1196. def test_errors(self):
  1197. # Testing errors...
  1198. try:
  1199. class C(list, dict):
  1200. pass
  1201. except TypeError:
  1202. pass
  1203. else:
  1204. self.fail("inheritance from both list and dict should be illegal")
  1205. try:
  1206. class C(object, None):
  1207. pass
  1208. except TypeError:
  1209. pass
  1210. else:
  1211. self.fail("inheritance from non-type should be illegal")
  1212. class Classic:
  1213. pass
  1214. try:
  1215. class C(type(len)):
  1216. pass
  1217. except TypeError:
  1218. pass
  1219. else:
  1220. self.fail("inheritance from CFunction should be illegal")
  1221. try:
  1222. class C(object):
  1223. __slots__ = 1
  1224. except TypeError:
  1225. pass
  1226. else:
  1227. self.fail("__slots__ = 1 should be illegal")
  1228. try:
  1229. class C(object):
  1230. __slots__ = [1]
  1231. except TypeError:
  1232. pass
  1233. else:
  1234. self.fail("__slots__ = [1] should be illegal")
  1235. class M1(type):
  1236. pass
  1237. class M2(type):
  1238. pass
  1239. class A1(object):
  1240. __metaclass__ = M1
  1241. class A2(object):
  1242. __metaclass__ = M2
  1243. try:
  1244. class B(A1, A2):
  1245. pass
  1246. except TypeError:
  1247. pass
  1248. else:
  1249. self.fail("finding the most derived metaclass should have failed")
  1250. def test_classmethods(self):
  1251. # Testing class methods...
  1252. class C(object):
  1253. def foo(*a): return a
  1254. goo = classmethod(foo)
  1255. c = C()
  1256. self.assertEqual(C.goo(1), (C, 1))
  1257. self.assertEqual(c.goo(1), (C, 1))
  1258. self.assertEqual(c.foo(1), (c, 1))
  1259. class D(C):
  1260. pass
  1261. d = D()
  1262. self.assertEqual(D.goo(1), (D, 1))
  1263. self.assertEqual(d.goo(1), (D, 1))
  1264. self.assertEqual(d.foo(1), (d, 1))
  1265. self.assertEqual(D.foo(d, 1), (d, 1))
  1266. # Test for a specific crash (SF bug 528132)
  1267. def f(cls, arg): return (cls, arg)
  1268. ff = classmethod(f)
  1269. self.assertEqual(ff.__get__(0, int)(42), (int, 42))
  1270. self.assertEqual(ff.__get__(0)(42), (int, 42))
  1271. # Test super() with classmethods (SF bug 535444)
  1272. self.assertEqual(C.goo.im_self, C)
  1273. self.assertEqual(D.goo.im_self, D)
  1274. self.assertEqual(super(D,D).goo.im_self, D)
  1275. self.assertEqual(super(D,d).goo.im_self, D)
  1276. self.assertEqual(super(D,D).goo(), (D,))
  1277. self.assertEqual(super(D,d).goo(), (D,))
  1278. # Verify that a non-callable will raise
  1279. meth = classmethod(1).__get__(1)
  1280. self.assertRaises(TypeError, meth)
  1281. # Verify that classmethod() doesn't allow keyword args
  1282. try:
  1283. classmethod(f, kw=1)
  1284. except TypeError:
  1285. pass
  1286. else:
  1287. self.fail("classmethod shouldn't accept keyword args")
  1288. @test_support.impl_detail("the module 'xxsubtype' is internal")
  1289. def test_classmethods_in_c(self):
  1290. # Testing C-based class methods...
  1291. import xxsubtype as spam
  1292. a = (1, 2, 3)
  1293. d = {'abc': 123}
  1294. x, a1, d1 = spam.spamlist.classmeth(*a, **d)
  1295. self.assertEqual(x, spam.spamlist)
  1296. self.assertEqual(a, a1)
  1297. self.assertEqual(d, d1)
  1298. x, a1, d1 = spam.spamlist().classmeth(*a, **d)
  1299. self.assertEqual(x, spam.spamlist)
  1300. self.assertEqual(a, a1)
  1301. self.assertEqual(d, d1)
  1302. def test_staticmethods(self):
  1303. # Testing static methods...
  1304. class C(object):
  1305. def foo(*a): return a
  1306. goo = staticmethod(foo)
  1307. c = C()
  1308. self.assertEqual(C.goo(1), (1,))
  1309. self.assertEqual(c.goo(1), (1,))
  1310. self.assertEqual(c.foo(1), (c, 1,))
  1311. class D(C):
  1312. pass
  1313. d = D()
  1314. self.assertEqual(D.goo(1), (1,))
  1315. self.assertEqual(d.goo(1), (1,))
  1316. self.assertEqual(d.foo(1), (d, 1))
  1317. self.assertEqual(D.foo(d, 1), (d, 1))
  1318. @test_support.impl_detail("the module 'xxsubtype' is internal")
  1319. def test_staticmethods_in_c(self):
  1320. # Testing C-based static methods...
  1321. import xxsubtype as spam
  1322. a = (1, 2, 3)
  1323. d = {"abc": 123}
  1324. x, a1, d1 = spam.spamlist.staticmeth(*a, **d)
  1325. self.assertEqual(x, None)
  1326. self.assertEqual(a, a1)
  1327. self.assertEqual(d, d1)
  1328. x, a1, d2 = spam.spamlist().staticmeth(*a, **d)
  1329. self.assertEqual(x, None)
  1330. self.assertEqual(a, a1)
  1331. self.assertEqual(d, d1)
  1332. def test_classic(self):
  1333. # Testing classic classes...
  1334. class C:
  1335. def foo(*a): return a
  1336. goo = classmethod(foo)
  1337. c = C()
  1338. self.assertEqual(C.goo(1), (C, 1))
  1339. self.assertEqual(c.goo(1), (C, 1))
  1340. self.assertEqual(c.foo(1), (c, 1))
  1341. class D(C):
  1342. pass
  1343. d = D()
  1344. self.assertEqual(D.goo(1), (D, 1))
  1345. self.assertEqual(d.goo(1), (D, 1))
  1346. self.assertEqual(d.foo(1), (d, 1))
  1347. self.assertEqual(D.foo(d, 1), (d, 1))
  1348. class E: # *not* subclassing from C
  1349. foo = C.foo
  1350. self.assertEqual(E().foo, C.foo) # i.e., unbound
  1351. self.assertTrue(repr(C.foo.__get__(C())).startswith("<bound method "))
  1352. def test_compattr(self):
  1353. # Testing computed attributes...
  1354. class C(object):
  1355. class computed_attribute(object):
  1356. def __init__(self, get, set=None, delete=None):
  1357. self.__get = get
  1358. self.__set = set
  1359. self.__delete = delete
  1360. def __get__(self, obj, type=None):
  1361. return self.__get(obj)
  1362. def __set__(self, obj, value):
  1363. return self.__set(obj, value)
  1364. def __delete__(self, obj):
  1365. return self.__delete(obj)
  1366. def __init__(self):
  1367. self.__x = 0
  1368. def __get_x(self):
  1369. x = self.__x
  1370. self.__x = x+1
  1371. return x
  1372. def __set_x(self, x):
  1373. self.__x = x
  1374. def __delete_x(self):
  1375. del self.__x
  1376. x = computed_attribute(__get_x, __set_x, __delete_x)
  1377. a = C()
  1378. self.assertEqual(a.x, 0)
  1379. self.assertEqual(a.x, 1)
  1380. a.x = 10
  1381. self.assertEqual(a.x, 10)
  1382. self.assertEqual(a.x, 11)
  1383. del a.x
  1384. self.assertEqual(hasattr(a, 'x'), 0)
  1385. def test_newslots(self):
  1386. # Testing __new__ slot override...
  1387. class C(list):
  1388. def __new__(cls):
  1389. self = list.__new__(cls)
  1390. self.foo = 1
  1391. return self
  1392. def __init__(self):
  1393. self.foo = self.foo + 2
  1394. a = C()
  1395. self.assertEqual(a.foo, 3)
  1396. self.assertEqual(a.__class__, C)
  1397. class D(C):
  1398. pass
  1399. b = D()
  1400. self.assertEqual(b.foo, 3)
  1401. self.assertEqual(b.__class__, D)
  1402. def test_altmro(self):
  1403. # Testing mro() and overriding it...
  1404. class A(object):
  1405. def f(self): return "A"
  1406. class B(A):
  1407. pass
  1408. class C(A):
  1409. def f(self): return "C"
  1410. class D(B, C):
  1411. pass
  1412. self.assertEqual(D.mro(), [D, B, C, A, object])
  1413. self.assertEqual(D.__mro__, (D, B, C, A, object))
  1414. self.assertEqual(D().f(), "C")
  1415. class PerverseMetaType(type):
  1416. def mro(cls):
  1417. L = type.mro(cls)
  1418. L.reverse()
  1419. return L
  1420. class X(D,B,C,A):
  1421. __metaclass__ = PerverseMetaType
  1422. self.assertEqual(X.__mro__, (object, A, C, B, D, X))
  1423. self.assertEqual(X().f(), "A")
  1424. try:
  1425. class X(object):
  1426. class __metaclass__(type):
  1427. def mro(self):
  1428. return [self, dict, object]
  1429. # In CPython, the class creation above already raises
  1430. # TypeError, as a protection against the fact that
  1431. # instances of X would segfault it. In other Python
  1432. # implementations it would be ok to let the class X
  1433. # be created, but instead get a clean TypeError on the
  1434. # __setitem__ below.
  1435. x = object.__new__(X)
  1436. x[5] = 6
  1437. except TypeError:
  1438. pass
  1439. else:
  1440. self.fail("devious mro() return not caught")
  1441. try:
  1442. class X(object):
  1443. class __metaclass__(type):
  1444. def mro(self):
  1445. return [1]
  1446. except TypeError:
  1447. pass
  1448. else:
  1449. self.fail("non-class mro() return not caught")
  1450. try:
  1451. class X(object):
  1452. class __metaclass__(type):
  1453. def mro(self):
  1454. return 1
  1455. except TypeError:
  1456. pass
  1457. else:
  1458. self.fail("non-sequence mro() return not caught")
  1459. def test_overloading(self):
  1460. # Testing operator overloading...
  1461. class B(object):
  1462. "Intermediate class because object doesn't have a __setattr__"
  1463. class C(B):
  1464. def __getattr__(self, name):
  1465. if name == "foo":
  1466. return ("getattr", name)
  1467. else:
  1468. raise AttributeError
  1469. def __setattr__(self, name, value):
  1470. if name == "foo":
  1471. self.setattr = (name, value)
  1472. else:
  1473. return B.__setattr__(self, name, value)
  1474. def __delattr__(self, name):
  1475. if name == "foo":
  1476. self.delattr = name
  1477. else:
  1478. return B.__delattr__(self, name)
  1479. def __getitem__(self, key):
  1480. return ("getitem", key)
  1481. def __setitem__(self, key, value):
  1482. self.setitem = (key, value)
  1483. def __delitem__(self, key):
  1484. self.delitem = key
  1485. def __getslice__(self, i, j):
  1486. return ("getslice", i, j)
  1487. def __setslice__(self, i, j, value):
  1488. self.setslice = (i, j, value)
  1489. def __delslice__(self, i, j):
  1490. self.delslice = (i, j)
  1491. a = C()
  1492. self.assertEqual(a.foo, ("getattr", "foo"))
  1493. a.foo = 12
  1494. self.assertEqual(a.setattr, ("foo", 12))
  1495. del a.foo
  1496. self.assertEqual(a.delattr, "foo")
  1497. self.assertEqual(a[12], ("getitem", 12))
  1498. a[12] = 21
  1499. self.assertEqual(a.setitem, (12, 21))
  1500. del a[12]
  1501. self.assertEqual(a.delitem, 12)
  1502. self.assertEqual(a[0:10], ("getslice", 0, 10))
  1503. a[0:10] = "foo"
  1504. self.assertEqual(a.setslice, (0, 10, "foo"))
  1505. del a[0:10]
  1506. self.assertEqual(a.delslice, (0, 10))
  1507. def test_methods(self):
  1508. # Testing methods...
  1509. class C(object):
  1510. def __init__(self, x):
  1511. self.x = x
  1512. def foo(self):
  1513. return self.x
  1514. c1 = C(1)
  1515. self.assertEqual(c1.foo(), 1)
  1516. class D(C):
  1517. boo = C.foo
  1518. goo = c1.foo
  1519. d2 = D(2)
  1520. self.assertEqual(d2.foo(), 2)
  1521. self.assertEqual(d2.boo(), 2)
  1522. self.assertEqual(d2.goo(), 1)
  1523. class E(object):
  1524. foo = C.foo
  1525. self.assertEqual(E().foo, C.foo) # i.e., unbound
  1526. self.assertTrue(repr(C.foo.__get__(C(1))).startswith("<bound method "))
  1527. def test_special_method_lookup(self):
  1528. # The lookup of special methods bypasses __getattr__ and
  1529. # __getattribute__, but they still can be descriptors.
  1530. def run_context(manager):
  1531. with manager:
  1532. pass
  1533. def iden(self):
  1534. return self
  1535. def hello(self):
  1536. return "hello"
  1537. def empty_seq(self):
  1538. return []
  1539. def zero(self):
  1540. return 0
  1541. def complex_num(self):
  1542. return 1j
  1543. def stop(self):
  1544. raise StopIteration
  1545. def return_true(self, thing=None):
  1546. return True
  1547. def do_isinstance(obj):
  1548. return isinstance(int, obj)
  1549. def do_issubclass(obj):
  1550. return issubclass(int, obj)
  1551. def swallow(*args):
  1552. pass
  1553. def do_dict_missing(checker):
  1554. class DictSub(checker.__class__, dict):
  1555. pass
  1556. self.assertEqual(DictSub()["hi"], 4)
  1557. def some_number(self_, key):
  1558. self.assertEqual(key, "hi")
  1559. return 4
  1560. def format_impl(self, spec):
  1561. return "hello"
  1562. # It would be nice to have every special method tested here, but I'm
  1563. # only listing the ones I can remember outside of typeobject.c, since it
  1564. # does it right.
  1565. specials = [
  1566. ("__unicode__", unicode, hello, set(), {}),
  1567. ("__reversed__", reversed, empty_seq, set(), {}),
  1568. ("__length_hint__", list, zero, set(),
  1569. {"__iter__" : iden, "next" : stop}),
  1570. ("__sizeof__", sys.getsizeof, zero, set(), {}),
  1571. ("__instancecheck__", do_isinstance, return_true, set(), {}),
  1572. ("__missing__", do_dict_missing, some_number,
  1573. set(("__class__",)), {}),
  1574. ("__subclasscheck__", do_issubclass, return_true,
  1575. set(("__bases__",)), {}),
  1576. ("__enter__", run_context, iden, set(), {"__exit__" : swallow}),
  1577. ("__exit__", run_context, swallow, set(), {"__enter__" : iden}),
  1578. ("__complex__", complex, complex_num, set(), {}),
  1579. ("__format__", format, format_impl, set(), {}),
  1580. ("__dir__", dir, empty_seq, set(), {}),
  1581. ]
  1582. class Checker(object):
  1583. def __getattr__(self, attr, test=self):
  1584. test.fail("__getattr__ called with {0}".format(attr))
  1585. def __getattribute__(self, attr, test=self):
  1586. if attr not in ok:
  1587. test.fail("__getattribute__ called with {0}".format(attr))
  1588. return object.__getattribute__(self, attr)
  1589. class SpecialDescr(object):
  1590. def __init__(self, impl):
  1591. self.impl = impl
  1592. def __get__(self, obj, owner):
  1593. record.append(1)
  1594. return self.impl.__get__(obj, owner)
  1595. class MyException(Exception):
  1596. pass
  1597. class ErrDescr(object):
  1598. def __get__(self, obj, owner):
  1599. raise MyException
  1600. for name, runner, meth_impl, ok, env in specials:
  1601. if name == '__length_hint__' or name == '__sizeof__':
  1602. if not test_support.check_impl_detail():
  1603. continue
  1604. class X(Checker):
  1605. pass
  1606. for attr, obj in env.iteritems():
  1607. setattr(X, attr, obj)
  1608. setattr(X, name, meth_impl)
  1609. runner(X())
  1610. record = []
  1611. class X(Checker):
  1612. pass
  1613. for attr, obj in env.iteritems():
  1614. setattr(X, attr, obj)
  1615. setattr(X, name, SpecialDescr(meth_impl))
  1616. runner(X())
  1617. self.assertEqual(record, [1], name)
  1618. class X(Checker):
  1619. pass
  1620. for attr, obj in env.iteritems():
  1621. setattr(X, attr, obj)
  1622. setattr(X, name, ErrDescr())
  1623. try:
  1624. runner(X())
  1625. except MyException:
  1626. pass
  1627. else:
  1628. self.fail("{0!r} didn't raise".format(name))
  1629. def test_specials(self):
  1630. # Testing special operators...
  1631. # Test operators like __hash__ for which a built-in default exists
  1632. # Test the default behavior for static classes
  1633. class C(object):
  1634. def __getitem__(self, i):
  1635. if 0 <= i < 10: return i
  1636. raise IndexError
  1637. c1 = C()
  1638. c2 = C()
  1639. self.assertTrue(not not c1) # What?
  1640. self.assertNotEqual(id(c1), id(c2))
  1641. hash(c1)
  1642. hash(c2)
  1643. self.assertEqual(cmp(c1, c2), cmp(id(c1), id(c2)))
  1644. self.assertEqual(c1, c1)
  1645. self.assertTrue(c1 != c2)
  1646. self.assertTrue(not c1 != c1)
  1647. self.assertTrue(not c1 == c2)
  1648. # Note that the module name appears in str/repr, and that varies
  1649. # depending on whether this test is run standalone or from a framework.
  1650. self.assertTrue(str(c1).find('C object at ') >= 0)
  1651. self.assertEqual(str(c1), repr(c1))
  1652. self.assertNotIn(-1, c1)
  1653. for i in range(10):
  1654. self.assertIn(i, c1)
  1655. self.assertNotIn(10, c1)
  1656. # Test the default behavior for dynamic classes
  1657. class D(object):
  1658. def __getitem__(self, i):
  1659. if 0 <= i < 10: return i
  1660. raise IndexError
  1661. d1 = D()
  1662. d2 = D()
  1663. self.assertTrue(not not d1)
  1664. self.assertNotEqual(id(d1), id(d2))
  1665. hash(d1)
  1666. hash(d2)
  1667. self.assertEqual(cmp(d1, d2), cmp(id(d1), id(d2)))
  1668. self.assertEqual(d1, d1)
  1669. self.assertNotEqual(d1, d2)
  1670. self.assertTrue(not d1 != d1)
  1671. self.assertTrue(not d1 == d2)
  1672. # Note that the module name appears in str/repr, and that varies
  1673. # depending on whether this test is run standalone or from a framework.
  1674. self.assertTrue(str(d1).find('D object at ') >= 0)
  1675. self.assertEqual(str(d1), repr(d1))
  1676. self.assertNotIn(-1, d1)
  1677. for i in range(10):
  1678. self.assertIn(i, d1)
  1679. self.assertNotIn(10, d1)
  1680. # Test overridden behavior for static classes
  1681. class Proxy(object):
  1682. def __init__(self, x):
  1683. self.x = x
  1684. def __nonzero__(self):
  1685. return not not self.x
  1686. def __hash__(self):
  1687. return hash(self.x)
  1688. def __eq__(self, other):
  1689. return self.x == other
  1690. def __ne__(self, other):
  1691. return self.x != other
  1692. def __cmp__(self, other):
  1693. return cmp(self.x, other.x)
  1694. def __str__(self):
  1695. return "Proxy:%s" % self.x
  1696. def __repr__(self):
  1697. return "Proxy(%r)" % self.x
  1698. def __contains__(self, value):
  1699. return value in self.x
  1700. p0 = Proxy(0)
  1701. p1 = Proxy(1)
  1702. p_1 = Proxy(-1)
  1703. self.assertFalse(p0)
  1704. self.assertTrue(not not p1)
  1705. self.assertEqual(hash(p0), hash(0))
  1706. self.assertEqual(p0, p0)
  1707. self.assertNotEqual(p0, p1)
  1708. self.assertTrue(not p0 != p0)
  1709. self.assertEqual(not p0, p1)
  1710. self.assertEqual(cmp(p0, p1), -1)
  1711. self.assertEqual(cmp(p0, p0), 0)
  1712. self.assertEqual(cmp(p0, p_1), 1)
  1713. self.assertEqual(str(p0), "Proxy:0")
  1714. self.assertEqual(repr(p0), "Proxy(0)")
  1715. p10 = Proxy(range(10))
  1716. self.assertNotIn(-1, p10)
  1717. for i in range(10):
  1718. self.assertIn(i, p10)
  1719. self.assertNotIn(10, p10)
  1720. # Test overridden behavior for dynamic classes
  1721. class DProxy(object):
  1722. def __init__(self, x):
  1723. self.x = x
  1724. def __nonzero__(self):
  1725. return not not self.x
  1726. def __hash__(self):
  1727. return hash(self.x)
  1728. def __eq__(self, other):
  1729. return self.x == other
  1730. def __ne__(self, other):
  1731. return self.x != other
  1732. def __cmp__(self, other):
  1733. return cmp(self.x, other.x)
  1734. def __str__(self):
  1735. return "DProxy:%s" % self.x
  1736. def __repr__(self):
  1737. return "DProxy(%r)" % self.x
  1738. def __contains__(self, value):
  1739. return value in self.x
  1740. p0 = DProxy(0)
  1741. p1 = DProxy(1)
  1742. p_1 = DProxy(-1)
  1743. self.assertFalse(p0)
  1744. self.assertTrue(not not p1)
  1745. self.assertEqual(hash(p0), hash(0))
  1746. self.assertEqual(p0, p0)
  1747. self.assertNotEqual(p0, p1)
  1748. self.assertNotEqual(not p0, p0)
  1749. self.assertEqual(not p0, p1)
  1750. self.assertEqual(cmp(p0, p1), -1)
  1751. self.assertEqual(cmp(p0, p0), 0)
  1752. self.assertEqual(cmp(p0, p_1), 1)
  1753. self.assertEqual(str(p0), "DProxy:0")
  1754. self.assertEqual(repr(p0), "DProxy(0)")
  1755. p10 = DProxy(range(10))
  1756. self.assertNotIn(-1, p10)
  1757. for i in range(10):
  1758. self.assertIn(i, p10)
  1759. self.assertNotIn(10, p10)
  1760. # Safety test for __cmp__
  1761. def unsafecmp(a, b):
  1762. if not hasattr(a, '__cmp__'):
  1763. return # some types don't have a __cmp__ any more (so the
  1764. # test doesn't make sense any more), or maybe they
  1765. # never had a __cmp__ at all, e.g. in PyPy
  1766. try:
  1767. a.__class__.__cmp__(a, b)
  1768. except TypeError:
  1769. pass
  1770. else:
  1771. self.fail("shouldn't allow %s.__cmp__(%r, %r)" % (
  1772. a.__class__, a, b))
  1773. unsafecmp(u"123", "123")
  1774. unsafecmp("123", u"123")
  1775. unsafecmp(1, 1.0)
  1776. unsafecmp(1.0, 1)
  1777. unsafecmp(1, 1L)
  1778. unsafecmp(1L, 1)
  1779. @test_support.impl_detail("custom logic for printing to real file objects")
  1780. def test_recursions_1(self):
  1781. # Testing recursion checks ...
  1782. class Letter(str):
  1783. def __new__(cls, letter):
  1784. if letter == 'EPS':
  1785. return str.__new__(cls)
  1786. return str.__new__(cls, letter)
  1787. def __str__(self):
  1788. if not self:
  1789. return 'EPS'
  1790. return self
  1791. # sys.stdout needs to be the original to trigger the recursion bug
  1792. test_stdout = sys.stdout
  1793. sys.stdout = test_support.get_original_stdout()
  1794. try:
  1795. # nothing should actually be printed, this should raise an exception
  1796. print Letter('w')
  1797. except RuntimeError:
  1798. pass
  1799. else:
  1800. self.fail("expected a RuntimeError for print recursion")
  1801. finally:
  1802. sys.stdout = test_stdout
  1803. def test_recursions_2(self):
  1804. # Bug #1202533.
  1805. class A(object):
  1806. pass
  1807. A.__mul__ = types.MethodType(lambda self, x: self * x, None, A)
  1808. try:
  1809. A()*2
  1810. except RuntimeError:
  1811. pass
  1812. else:
  1813. self.fail("expected a RuntimeError")
  1814. def test_weakrefs(self):
  1815. # Testing weak references...
  1816. import weakref
  1817. class C(object):
  1818. pass
  1819. c = C()
  1820. r = weakref.ref(c)
  1821. self.assertEqual(r(), c)
  1822. del c
  1823. test_support.gc_collect()
  1824. self.assertEqual(r(), None)
  1825. del r
  1826. class NoWeak(object):
  1827. __slots__ = ['foo']
  1828. no = NoWeak()
  1829. try:
  1830. weakref.ref(no)
  1831. except TypeError, msg:
  1832. self.assertTrue(str(msg).find("weak reference") >= 0)
  1833. else:
  1834. if test_support.check_impl_detail(pypy=False):
  1835. self.fail("weakref.ref(no) should be illegal")
  1836. #else: pypy supports taking weakrefs to some more objects
  1837. class Weak(object):
  1838. __slots__ = ['foo', '__weakref__']
  1839. yes = Weak()
  1840. r = weakref.ref(yes)
  1841. self.assertEqual(r(), yes)
  1842. del yes
  1843. test_support.gc_collect()
  1844. self.assertEqual(r(), None)
  1845. del r
  1846. def test_properties(self):
  1847. # Testing property...
  1848. class C(object):
  1849. def getx(self):
  1850. return self.__x
  1851. def setx(self, value):
  1852. self.__x = value
  1853. def delx(self):
  1854. del self.__x
  1855. x = property(getx, setx, delx, doc="I'm the x property.")
  1856. a = C()
  1857. self.assertFalse(hasattr(a, "x"))
  1858. a.x = 42
  1859. self.assertEqual(a._C__x, 42)
  1860. self.assertEqual(a.x, 42)
  1861. del a.x
  1862. self.assertFalse(hasattr(a, "x"))
  1863. self.assertFalse(hasattr(a, "_C__x"))
  1864. C.x.__set__(a, 100)
  1865. self.assertEqual(C.x.__get__(a), 100)
  1866. C.x.__delete__(a)
  1867. self.assertFalse(hasattr(a, "x"))
  1868. raw = C.__dict__['x']
  1869. self.assertIsInstance(raw, property)
  1870. attrs = dir(raw)
  1871. self.assertIn("__doc__", attrs)
  1872. self.assertIn("fget", attrs)
  1873. self.assertIn("fset", attrs)
  1874. self.assertIn("fdel", attrs)
  1875. self.assertEqual(raw.__doc__, "I'm the x property.")
  1876. self.assertTrue(raw.fget is C.__dict__['getx'])
  1877. self.assertTrue(raw.fset is C.__dict__['setx'])
  1878. self.assertTrue(raw.fdel is C.__dict__['delx'])
  1879. for attr in "__doc__", "fget", "fset", "fdel":
  1880. try:
  1881. setattr(raw, attr, 42)
  1882. except TypeError, msg:
  1883. if str(msg).find('readonly') < 0:
  1884. self.fail("when setting readonly attr %r on a property, "
  1885. "got unexpected TypeError msg %r" % (attr, str(msg)))
  1886. else:
  1887. self.fail("expected TypeError from trying to set readonly %r "
  1888. "attr on a property" % attr)
  1889. class D(object):
  1890. __getitem__ = property(lambda s: 1/0)
  1891. d = D()
  1892. try:
  1893. for i in d:
  1894. str(i)
  1895. except ZeroDivisionError:
  1896. pass
  1897. else:
  1898. self.fail("expected ZeroDivisionError from bad property")
  1899. @unittest.skipIf(sys.flags.optimize >= 2,
  1900. "Docstrings are omitted with -O2 and above")
  1901. def test_properties_doc_attrib(self):
  1902. class E(object):
  1903. def getter(self):
  1904. "getter method"
  1905. return 0
  1906. def setter(self_, value):
  1907. "setter method"
  1908. pass
  1909. prop = property(getter)
  1910. self.assertEqual(prop.__doc__, "getter method")
  1911. prop2 = property(fset=setter)
  1912. self.assertEqual(prop2.__doc__, None)
  1913. def test_testcapi_no_segfault(self):
  1914. # this segfaulted in 2.5b2
  1915. try:
  1916. import _testcapi
  1917. except ImportError:
  1918. pass
  1919. else:
  1920. class X(object):
  1921. p = property(_testcapi.test_with_docstring)
  1922. def test_properties_plus(self):
  1923. class C(object):
  1924. foo = property(doc="hello")
  1925. @foo.getter
  1926. def foo(self):
  1927. return self._foo
  1928. @foo.setter
  1929. def foo(self, value):
  1930. self._foo = abs(value)
  1931. @foo.deleter
  1932. def foo(self):
  1933. del self._foo
  1934. c = C()
  1935. self.assertEqual(C.foo.__doc__, "hello")
  1936. self.assertFalse(hasattr(c, "foo"))
  1937. c.foo = -42
  1938. self.assertTrue(hasattr(c, '_foo'))
  1939. self.assertEqual(c._foo, 42)
  1940. self.assertEqual(c.foo, 42)
  1941. del c.foo
  1942. self.assertFalse(hasattr(c, '_foo'))
  1943. self.assertFalse(hasattr(c, "foo"))
  1944. class D(C):
  1945. @C.foo.deleter
  1946. def foo(self):
  1947. try:
  1948. del self._foo
  1949. except AttributeError:
  1950. pass
  1951. d = D()
  1952. d.foo = 24
  1953. self.assertEqual(d.foo, 24)
  1954. del d.foo
  1955. del d.foo
  1956. class E(object):
  1957. @property
  1958. def foo(self):
  1959. return self._foo
  1960. @foo.setter
  1961. def foo(self, value):
  1962. raise RuntimeError
  1963. @foo.setter
  1964. def foo(self, value):
  1965. self._foo = abs(value)
  1966. @foo.deleter
  1967. def foo(self, value=None):
  1968. del self._foo
  1969. e = E()
  1970. e.foo = -42
  1971. self.assertEqual(e.foo, 42)
  1972. del e.foo
  1973. class F(E):
  1974. @E.foo.deleter
  1975. def foo(self):
  1976. del self._foo
  1977. @foo.setter
  1978. def foo(self, value):
  1979. self._foo = max(0, value)
  1980. f = F()
  1981. f.foo = -10
  1982. self.assertEqual(f.foo, 0)
  1983. del f.foo
  1984. def test_dict_constructors(self):
  1985. # Testing dict constructor ...
  1986. d = dict()
  1987. self.assertEqual(d, {})
  1988. d = dict({})
  1989. self.assertEqual(d, {})
  1990. d = dict({1: 2, 'a': 'b'})
  1991. self.assertEqual(d, {1: 2, 'a': 'b'})
  1992. self.assertEqual(d, dict(d.items()))
  1993. self.assertEqual(d, dict(d.iteritems()))
  1994. d = dict({'one':1, 'two':2})
  1995. self.assertEqual(d, dict(one=1, two=2))
  1996. self.assertEqual(d, dict(**d))
  1997. self.assertEqual(d, dict({"one": 1}, two=2))
  1998. self.assertEqual(d, dict([("two", 2)], one=1))
  1999. self.assertEqual(d, dict([("one", 100), ("two", 200)], **d))
  2000. self.assertEqual(d, dict(**d))
  2001. for badarg in 0, 0L, 0j, "0", [0], (0,):
  2002. try:
  2003. dict(badarg)
  2004. except TypeError:
  2005. pass
  2006. except ValueError:
  2007. if badarg == "0":
  2008. # It's a sequence, and its elements are also sequences (gotta
  2009. # love strings <wink>), but they aren't of length 2, so this
  2010. # one seemed better as a ValueError than a TypeError.
  2011. pass
  2012. else:
  2013. self.fail("no TypeError from dict(%r)" % badarg)
  2014. else:
  2015. self.fail("no TypeError from dict(%r)" % badarg)
  2016. try:
  2017. dict({}, {})
  2018. except TypeError:
  2019. pass
  2020. else:
  2021. self.fail("no TypeError from dict({}, {})")
  2022. class Mapping:
  2023. # Lacks a .keys() method; will be added later.
  2024. dict = {1:2, 3:4, 'a':1j}
  2025. try:
  2026. dict(Mapping())
  2027. except TypeError:
  2028. pass
  2029. else:
  2030. self.fail("no TypeError from dict(incomplete mapping)")
  2031. Mapping.keys = lambda self: self.dict.keys()
  2032. Mapping.__getitem__ = lambda self, i: self.dict[i]
  2033. d = dict(Mapping())
  2034. self.assertEqual(d, Mapping.dict)
  2035. # Init from sequence of iterable objects, each producing a 2-sequence.
  2036. class AddressBookEntry:
  2037. def __init__(self, first, last):
  2038. self.first = first
  2039. self.last = last
  2040. def __iter__(self):
  2041. return iter([self.first, self.last])
  2042. d = dict([AddressBookEntry('Tim', 'Warsaw'),
  2043. AddressBookEntry('Barry', 'Peters'),
  2044. AddressBookEntry('Tim', 'Peters'),
  2045. AddressBookEntry('Barry', 'Warsaw')])
  2046. self.assertEqual(d, {'Barry': 'Warsaw', 'Tim': 'Peters'})
  2047. d = dict(zip(range(4), range(1, 5)))
  2048. self.assertEqual(d, dict([(i, i+1) for i in range(4)]))
  2049. # Bad sequence lengths.
  2050. for bad in [('tooshort',)], [('too', 'long', 'by 1')]:
  2051. try:
  2052. dict(bad)
  2053. except ValueError:
  2054. pass
  2055. else:
  2056. self.fail("no ValueError from dict(%r)" % bad)
  2057. def test_dir(self):
  2058. # Testing dir() ...
  2059. junk = 12
  2060. self.assertEqual(dir(), ['junk', 'self'])
  2061. del junk
  2062. # Just make sure these don't blow up!
  2063. for arg in 2, 2L, 2j, 2e0, [2], "2", u"2", (2,), {2:2}, type, self.test_dir:
  2064. dir(arg)
  2065. # Try classic classes.
  2066. class C:
  2067. Cdata = 1
  2068. def Cmethod(self): pass
  2069. cstuff = ['Cdata', 'Cmethod', '__doc__', '__module__']
  2070. self.assertEqual(dir(C), cstuff)
  2071. self.assertIn('im_self', dir(C.Cmethod))
  2072. c = C() # c.__doc__ is an odd thing to see here; ditto c.__module__.
  2073. self.assertEqual(dir(c), cstuff)
  2074. c.cdata = 2
  2075. c.cmethod = lambda self: 0
  2076. self.assertEqual(dir(c), cstuff + ['cdata', 'cmethod'])
  2077. self.assertIn('im_self', dir(c.Cmethod))
  2078. class A(C):
  2079. Adata = 1
  2080. def Amethod(self): pass
  2081. astuff = ['Adata', 'Amethod'] + cstuff
  2082. self.assertEqual(dir(A), astuff)
  2083. self.assertIn('im_self', dir(A.Amethod))
  2084. a = A()
  2085. self.assertEqual(dir(a), astuff)
  2086. self.assertIn('im_self', dir(a.Amethod))
  2087. a.adata = 42
  2088. a.amethod = lambda self: 3
  2089. self.assertEqual(dir(a), astuff + ['adata', 'amethod'])
  2090. # The same, but with new-style classes. Since these have object as a
  2091. # base class, a lot more gets sucked in.
  2092. def interesting(strings):
  2093. return [s for s in strings if not s.startswith('_')]
  2094. class C(object):
  2095. Cdata = 1
  2096. def Cmethod(self): pass
  2097. cstuff = ['Cdata', 'Cmethod']
  2098. self.assertEqual(interesting(dir(C)), cstuff)
  2099. c = C()
  2100. self.assertEqual(interesting(dir(c)), cstuff)
  2101. self.assertIn('im_self', dir(C.Cmethod))
  2102. c.cdata = 2
  2103. c.cmethod = lambda self: 0
  2104. self.assertEqual(interesting(dir(c)), cstuff + ['cdata', 'cmethod'])
  2105. self.assertIn('im_self', dir(c.Cmethod))
  2106. class A(C):
  2107. Adata = 1
  2108. def Amethod(self): pass
  2109. astuff = ['Adata', 'Amethod'] + cstuff
  2110. self.assertEqual(interesting(dir(A)), astuff)
  2111. self.assertIn('im_self', dir(A.Amethod))
  2112. a = A()
  2113. self.assertEqual(interesting(dir(a)), astuff)
  2114. a.adata = 42
  2115. a.amethod = lambda self: 3
  2116. self.assertEqual(interesting(dir(a)), astuff + ['adata', 'amethod'])
  2117. self.assertIn('im_self', dir(a.Amethod))
  2118. # Try a module subclass.
  2119. class M(type(sys)):
  2120. pass
  2121. minstance = M("m")
  2122. minstance.b = 2
  2123. minstance.a = 1
  2124. names = [x for x in dir(minstance) if x not in ["__name__", "__doc__"]]
  2125. self.assertEqual(names, ['a', 'b'])
  2126. class M2(M):
  2127. def getdict(self):
  2128. return "Not a dict!"
  2129. __dict__ = property(getdict)
  2130. m2instance = M2("m2")
  2131. m2instance.b = 2
  2132. m2instance.a = 1
  2133. self.assertEqual(m2instance.__dict__, "Not a dict!")
  2134. try:
  2135. dir(m2instance)
  2136. except TypeError:
  2137. pass
  2138. # Two essentially featureless objects, just inheriting stuff from
  2139. # object.
  2140. self.assertEqual(dir(NotImplemented), dir(Ellipsis))
  2141. if test_support.check_impl_detail():
  2142. # None differs in PyPy: it has a __nonzero__
  2143. self.assertEqual(dir(None), dir(Ellipsis))
  2144. # Nasty test case for proxied objects
  2145. class Wrapper(object):
  2146. def __init__(self, obj):
  2147. self.__obj = obj
  2148. def __repr__(self):
  2149. return "Wrapper(%s)" % repr(self.__obj)
  2150. def __getitem__(self, key):
  2151. return Wrapper(self.__obj[key])
  2152. def __len__(self):
  2153. return len(self.__obj)
  2154. def __getattr__(self, name):
  2155. return Wrapper(getattr(self.__obj, name))
  2156. class C(object):
  2157. def __getclass(self):
  2158. return Wrapper(type(self))
  2159. __class__ = property(__getclass)
  2160. dir(C()) # This used to segfault
  2161. def test_supers(self):
  2162. # Testing super...
  2163. class A(object):
  2164. def meth(self, a):
  2165. return "A(%r)" % a
  2166. self.assertEqual(A().meth(1), "A(1)")
  2167. class B(A):
  2168. def __init__(self):
  2169. self.__super = super(B, self)
  2170. def meth(self, a):
  2171. return "B(%r)" % a + self.__super.meth(a)
  2172. self.assertEqual(B().meth(2), "B(2)A(2)")
  2173. class C(A):
  2174. def meth(self, a):
  2175. return "C(%r)" % a + self.__super.meth(a)
  2176. C._C__super = super(C)
  2177. self.assertEqual(C().meth(3), "C(3)A(3)")
  2178. class D(C, B):
  2179. def meth(self, a):
  2180. return "D(%r)" % a + super(D, self).meth(a)
  2181. self.assertEqual(D().meth(4), "D(4)C(4)B(4)A(4)")
  2182. # Test for subclassing super
  2183. class mysuper(super):
  2184. def __init__(self, *args):
  2185. return super(mysuper, self).__init__(*args)
  2186. class E(D):
  2187. def meth(self, a):
  2188. return "E(%r)" % a + mysuper(E, self).meth(a)
  2189. self.assertEqual(E().meth(5), "E(5)D(5)C(5)B(5)A(5)")
  2190. class F(E):
  2191. def meth(self, a):
  2192. s = self.__super # == mysuper(F, self)
  2193. return "F(%r)[%s]" % (a, s.__class__.__name__) + s.meth(a)
  2194. F._F__super = mysuper(F)
  2195. self.assertEqual(F().meth(6), "F(6)[mysuper]E(6)D(6)C(6)B(6)A(6)")
  2196. # Make sure certain errors are raised
  2197. try:
  2198. super(D, 42)
  2199. except TypeError:
  2200. pass
  2201. else:
  2202. self.fail("shouldn't allow super(D, 42)")
  2203. try:
  2204. super(D, C())
  2205. except TypeError:
  2206. pass
  2207. else:
  2208. self.fail("shouldn't allow super(D, C())")
  2209. try:
  2210. super(D).__get__(12)
  2211. except TypeError:
  2212. pass
  2213. else:
  2214. self.fail("shouldn't allow super(D).__get__(12)")
  2215. try:
  2216. super(D).__get__(C())
  2217. except TypeError:
  2218. pass
  2219. else:
  2220. self.fail("shouldn't allow super(D).__get__(C())")
  2221. # Make sure data descriptors can be overridden and accessed via super
  2222. # (new feature in Python 2.3)
  2223. class DDbase(object):
  2224. def getx(self): return 42
  2225. x = property(getx)
  2226. class DDsub(DDbase):
  2227. def getx(self): return "hello"
  2228. x = property(getx)
  2229. dd = DDsub()
  2230. self.assertEqual(dd.x, "hello")
  2231. self.assertEqual(super(DDsub, dd).x, 42)
  2232. # Ensure that super() lookup of descriptor from classmethod
  2233. # works (SF ID# 743627)
  2234. class Base(object):
  2235. aProp = property(lambda self: "foo")
  2236. class Sub(Base):
  2237. @classmethod
  2238. def test(klass):
  2239. return super(Sub,klass).aProp
  2240. self.assertEqual(Sub.test(), Base.aProp)
  2241. # Verify that super() doesn't allow keyword args
  2242. try:
  2243. super(Base, kw=1)
  2244. except TypeError:
  2245. pass
  2246. else:
  2247. self.assertEqual("super shouldn't accept keyword args")
  2248. def test_basic_inheritance(self):
  2249. # Testing inheritance from basic types...
  2250. class hexint(int):
  2251. def __repr__(self):
  2252. return hex(self)
  2253. def __add__(self, other):
  2254. return hexint(int.__add__(self, other))
  2255. # (Note that overriding __radd__ doesn't work,
  2256. # because the int type gets first dibs.)
  2257. self.assertEqual(repr(hexint(7) + 9), "0x10")
  2258. self.assertEqual(repr(hexint(1000) + 7), "0x3ef")
  2259. a = hexint(12345)
  2260. self.assertEqual(a, 12345)
  2261. self.assertEqual(int(a), 12345)
  2262. self.assertTrue(int(a).__class__ is int)
  2263. self.assertEqual(hash(a), hash(12345))
  2264. self.assertTrue((+a).__class__ is int)
  2265. self.assertTrue((a >> 0).__class__ is int)
  2266. self.assertTrue((a << 0).__class__ is int)
  2267. self.assertTrue((hexint(0) << 12).__class__ is int)
  2268. self.assertTrue((hexint(0) >> 12).__class__ is int)
  2269. class octlong(long):
  2270. __slots__ = []
  2271. def __str__(self):
  2272. s = oct(self)
  2273. if s[-1] == 'L':
  2274. s = s[:-1]
  2275. return s
  2276. def __add__(self, other):
  2277. return self.__class__(super(octlong, self).__add__(other))
  2278. __radd__ = __add__
  2279. self.assertEqual(str(octlong(3) + 5), "010")
  2280. # (Note that overriding __radd__ here only seems to work
  2281. # because the example uses a short int left argument.)
  2282. self.assertEqual(str(5 + octlong(3000)), "05675")
  2283. a = octlong(12345)
  2284. self.assertEqual(a, 12345L)
  2285. self.assertEqual(long(a), 12345L)
  2286. self.assertEqual(hash(a), hash(12345L))
  2287. self.assertTrue(long(a).__class__ is long)
  2288. self.assertTrue((+a).__class__ is long)
  2289. self.assertTrue((-a).__class__ is long)
  2290. self.assertTrue((-octlong(0)).__class__ is long)
  2291. self.assertTrue((a >> 0).__class__ is long)
  2292. self.assertTrue((a << 0).__class__ is long)
  2293. self.assertTrue((a - 0).__class__ is long)
  2294. self.assertTrue((a * 1).__class__ is long)
  2295. self.assertTrue((a ** 1).__class__ is long)
  2296. self.assertTrue((a // 1).__class__ is long)
  2297. self.assertTrue((1 * a).__class__ is long)
  2298. self.assertTrue((a | 0).__class__ is long)
  2299. self.assertTrue((a ^ 0).__class__ is long)
  2300. self.assertTrue((a & -1L).__class__ is long)
  2301. self.assertTrue((octlong(0) << 12).__class__ is long)
  2302. self.assertTrue((octlong(0) >> 12).__class__ is long)
  2303. self.assertTrue(abs(octlong(0)).__class__ is long)
  2304. # Because octlong overrides __add__, we can't check the absence of +0
  2305. # optimizations using octlong.
  2306. class longclone(long):
  2307. pass
  2308. a = longclone(1)
  2309. self.assertTrue((a + 0).__class__ is long)
  2310. self.assertTrue((0 + a).__class__ is long)
  2311. # Check that negative clones don't segfault
  2312. a = longclone(-1)
  2313. self.assertEqual(a.__dict__, {})
  2314. self.assertEqual(long(a), -1) # self.assertTrue PyNumber_Long() copies the sign bit
  2315. class precfloat(float):
  2316. __slots__ = ['prec']
  2317. def __init__(self, value=0.0, prec=12):
  2318. self.prec = int(prec)
  2319. def __repr__(self):
  2320. return "%.*g" % (self.prec, self)
  2321. self.assertEqual(repr(precfloat(1.1)), "1.1")
  2322. a = precfloat(12345)
  2323. self.assertEqual(a, 12345.0)
  2324. self.assertEqual(float(a), 12345.0)
  2325. self.assertTrue(float(a).__class__ is float)
  2326. self.assertEqual(hash(a), hash(12345.0))
  2327. self.assertTrue((+a).__class__ is float)
  2328. class madcomplex(complex):
  2329. def __repr__(self):
  2330. return "%.17gj%+.17g" % (self.imag, self.real)
  2331. a = madcomplex(-3, 4)
  2332. self.assertEqual(repr(a), "4j-3")
  2333. base = complex(-3, 4)
  2334. self.assertEqual(base.__class__, complex)
  2335. self.assertEqual(a, base)
  2336. self.assertEqual(complex(a), base)
  2337. self.assertEqual(complex(a).__class__, complex)
  2338. a = madcomplex(a) # just trying another form of the constructor
  2339. self.assertEqual(repr(a), "4j-3")
  2340. self.assertEqual(a, base)
  2341. self.assertEqual(complex(a), base)
  2342. self.assertEqual(complex(a).__class__, complex)
  2343. self.assertEqual(hash(a), hash(base))
  2344. self.assertEqual((+a).__class__, complex)
  2345. self.assertEqual((a + 0).__class__, complex)
  2346. self.assertEqual(a + 0, base)
  2347. self.assertEqual((a - 0).__class__, complex)
  2348. self.assertEqual(a - 0, base)
  2349. self.assertEqual((a * 1).__class__, complex)
  2350. self.assertEqual(a * 1, base)
  2351. self.assertEqual((a / 1).__class__, complex)
  2352. self.assertEqual(a / 1, base)
  2353. class madtuple(tuple):
  2354. _rev = None
  2355. def rev(self):
  2356. if self._rev is not None:
  2357. return self._rev
  2358. L = list(self)
  2359. L.reverse()
  2360. self._rev = self.__class__(L)
  2361. return self._rev
  2362. a = madtuple((1,2,3,4,5,6,7,8,9,0))
  2363. self.assertEqual(a, (1,2,3,4,5,6,7,8,9,0))
  2364. self.assertEqual(a.rev(), madtuple((0,9,8,7,6,5,4,3,2,1)))
  2365. self.assertEqual(a.rev().rev(), madtuple((1,2,3,4,5,6,7,8,9,0)))
  2366. for i in range(512):
  2367. t = madtuple(range(i))
  2368. u = t.rev()
  2369. v = u.rev()
  2370. self.assertEqual(v, t)
  2371. a = madtuple((1,2,3,4,5))
  2372. self.assertEqual(tuple(a), (1,2,3,4,5))
  2373. self.assertTrue(tuple(a).__class__ is tuple)
  2374. self.assertEqual(hash(a), hash((1,2,3,4,5)))
  2375. self.assertTrue(a[:].__class__ is tuple)
  2376. self.assertTrue((a * 1).__class__ is tuple)
  2377. self.assertTrue((a * 0).__class__ is tuple)
  2378. self.assertTrue((a + ()).__class__ is tuple)
  2379. a = madtuple(())
  2380. self.assertEqual(tuple(a), ())
  2381. self.assertTrue(tuple(a).__class__ is tuple)
  2382. self.assertTrue((a + a).__class__ is tuple)
  2383. self.assertTrue((a * 0).__class__ is tuple)
  2384. self.assertTrue((a * 1).__class__ is tuple)
  2385. self.assertTrue((a * 2).__class__ is tuple)
  2386. self.assertTrue(a[:].__class__ is tuple)
  2387. class madstring(str):
  2388. _rev = None
  2389. def rev(self):
  2390. if self._rev is not None:
  2391. return self._rev
  2392. L = list(self)
  2393. L.reverse()
  2394. self._rev = self.__class__("".join(L))
  2395. return self._rev
  2396. s = madstring("abcdefghijklmnopqrstuvwxyz")
  2397. self.assertEqual(s, "abcdefghijklmnopqrstuvwxyz")
  2398. self.assertEqual(s.rev(), madstring("zyxwvutsrqponmlkjihgfedcba"))
  2399. self.assertEqual(s.rev().rev(), madstring("abcdefghijklmnopqrstuvwxyz"))
  2400. for i in range(256):
  2401. s = madstring("".join(map(chr, range(i))))
  2402. t = s.rev()
  2403. u = t.rev()
  2404. self.assertEqual(u, s)
  2405. s = madstring("12345")
  2406. self.assertEqual(str(s), "12345")
  2407. self.assertTrue(str(s).__class__ is str)
  2408. base = "\x00" * 5
  2409. s = madstring(base)
  2410. self.assertEqual(s, base)
  2411. self.assertEqual(str(s), base)
  2412. self.assertTrue(str(s).__class__ is str)
  2413. self.assertEqual(hash(s), hash(base))
  2414. self.assertEqual({s: 1}[base], 1)
  2415. self.assertEqual({base: 1}[s], 1)
  2416. self.assertTrue((s + "").__class__ is str)
  2417. self.assertEqual(s + "", base)
  2418. self.assertTrue(("" + s).__class__ is str)
  2419. self.assertEqual("" + s, base)
  2420. self.assertTrue((s * 0).__class__ is str)
  2421. self.assertEqual(s * 0, "")
  2422. self.assertTrue((s * 1).__class__ is str)
  2423. self.assertEqual(s * 1, base)
  2424. self.assertTrue((s * 2).__class__ is str)
  2425. self.assertEqual(s * 2, base + base)
  2426. self.assertTrue(s[:].__class__ is str)
  2427. self.assertEqual(s[:], base)
  2428. self.assertTrue(s[0:0].__class__ is str)
  2429. self.assertEqual(s[0:0], "")
  2430. self.assertTrue(s.strip().__class__ is str)
  2431. self.assertEqual(s.strip(), base)
  2432. self.assertTrue(s.lstrip().__class__ is str)
  2433. self.assertEqual(s.lstrip(), base)
  2434. self.assertTrue(s.rstrip().__class__ is str)
  2435. self.assertEqual(s.rstrip(), base)
  2436. identitytab = ''.join([chr(i) for i in range(256)])
  2437. self.assertTrue(s.translate(identitytab).__class__ is str)
  2438. self.assertEqual(s.translate(identitytab), base)
  2439. self.assertTrue(s.translate(identitytab, "x").__class__ is str)
  2440. self.assertEqual(s.translate(identitytab, "x"), base)
  2441. self.assertEqual(s.translate(identitytab, "\x00"), "")
  2442. self.assertTrue(s.replace("x", "x").__class__ is str)
  2443. self.assertEqual(s.replace("x", "x"), base)
  2444. self.assertTrue(s.ljust(len(s)).__class__ is str)
  2445. self.assertEqual(s.ljust(len(s)), base)
  2446. self.assertTrue(s.rjust(len(s)).__class__ is str)
  2447. self.assertEqual(s.rjust(len(s)), base)
  2448. self.assertTrue(s.center(len(s)).__class__ is str)
  2449. self.assertEqual(s.center(len(s)), base)
  2450. self.assertTrue(s.lower().__class__ is str)
  2451. self.assertEqual(s.lower(), base)
  2452. class madunicode(unicode):
  2453. _rev = None
  2454. def rev(self):
  2455. if self._rev is not None:
  2456. return self._rev
  2457. L = list(self)
  2458. L.reverse()
  2459. self._rev = self.__class__(u"".join(L))
  2460. return self._rev
  2461. u = madunicode("ABCDEF")
  2462. self.assertEqual(u, u"ABCDEF")
  2463. self.assertEqual(u.rev(), madunicode(u"FEDCBA"))
  2464. self.assertEqual(u.rev().rev(), madunicode(u"ABCDEF"))
  2465. base = u"12345"
  2466. u = madunicode(base)
  2467. self.assertEqual(unicode(u), base)
  2468. self.assertTrue(unicode(u).__class__ is unicode)
  2469. self.assertEqual(hash(u), hash(base))
  2470. self.assertEqual({u: 1}[base], 1)
  2471. self.assertEqual({base: 1}[u], 1)
  2472. self.assertTrue(u.strip().__class__ is unicode)
  2473. self.assertEqual(u.strip(), base)
  2474. self.assertTrue(u.lstrip().__class__ is unicode)
  2475. self.assertEqual(u.lstrip(), base)
  2476. self.assertTrue(u.rstrip().__class__ is unicode)
  2477. self.assertEqual(u.rstrip(), base)
  2478. self.assertTrue(u.replace(u"x", u"x").__class__ is unicode)
  2479. self.assertEqual(u.replace(u"x", u"x"), base)
  2480. self.assertTrue(u.replace(u"xy", u"xy").__class__ is unicode)
  2481. self.assertEqual(u.replace(u"xy", u"xy"), base)
  2482. self.assertTrue(u.center(len(u)).__class__ is unicode)
  2483. self.assertEqual(u.center(len(u)), base)
  2484. self.assertTrue(u.ljust(len(u)).__class__ is unicode)
  2485. self.assertEqual(u.ljust(len(u)), base)
  2486. self.assertTrue(u.rjust(len(u)).__class__ is unicode)
  2487. self.assertEqual(u.rjust(len(u)), base)
  2488. self.assertTrue(u.lower().__class__ is unicode)
  2489. self.assertEqual(u.lower(), base)
  2490. self.assertTrue(u.upper().__class__ is unicode)
  2491. self.assertEqual(u.upper(), base)
  2492. self.assertTrue(u.capitalize().__class__ is unicode)
  2493. self.assertEqual(u.capitalize(), base)
  2494. self.assertTrue(u.title().__class__ is unicode)
  2495. self.assertEqual(u.title(), base)
  2496. self.assertTrue((u + u"").__class__ is unicode)
  2497. self.assertEqual(u + u"", base)
  2498. self.assertTrue((u"" + u).__class__ is unicode)
  2499. self.assertEqual(u"" + u, base)
  2500. self.assertTrue((u * 0).__class__ is unicode)
  2501. self.assertEqual(u * 0, u"")
  2502. self.assertTrue((u * 1).__class__ is unicode)
  2503. self.assertEqual(u * 1, base)
  2504. self.assertTrue((u * 2).__class__ is unicode)
  2505. self.assertEqual(u * 2, base + base)
  2506. self.assertTrue(u[:].__class__ is unicode)
  2507. self.assertEqual(u[:], base)
  2508. self.assertTrue(u[0:0].__class__ is unicode)
  2509. self.assertEqual(u[0:0], u"")
  2510. class sublist(list):
  2511. pass
  2512. a = sublist(range(5))
  2513. self.assertEqual(a, range(5))
  2514. a.append("hello")
  2515. self.assertEqual(a, range(5) + ["hello"])
  2516. a[5] = 5
  2517. self.assertEqual(a, range(6))
  2518. a.extend(range(6, 20))
  2519. self.assertEqual(a, range(20))
  2520. a[-5:] = []
  2521. self.assertEqual(a, range(15))
  2522. del a[10:15]
  2523. self.assertEqual(len(a), 10)
  2524. self.assertEqual(a, range(10))
  2525. self.assertEqual(list(a), range(10))
  2526. self.assertEqual(a[0], 0)
  2527. self.assertEqual(a[9], 9)
  2528. self.assertEqual(a[-10], 0)
  2529. self.assertEqual(a[-1], 9)
  2530. self.assertEqual(a[:5], range(5))
  2531. class CountedInput(file):
  2532. """Counts lines read by self.readline().
  2533. self.lineno is the 0-based ordinal of the last line read, up to
  2534. a maximum of one greater than the number of lines in the file.
  2535. self.ateof is true if and only if the final "" line has been read,
  2536. at which point self.lineno stops incrementing, and further calls
  2537. to readline() continue to return "".
  2538. """
  2539. lineno = 0
  2540. ateof = 0
  2541. def readline(self):
  2542. if self.ateof:
  2543. return ""
  2544. s = file.readline(self)
  2545. # Next line works too.
  2546. # s = super(CountedInput, self).readline()
  2547. self.lineno += 1
  2548. if s == "":
  2549. self.ateof = 1
  2550. return s
  2551. f = file(name=test_support.TESTFN, mode='w')
  2552. lines = ['a\n', 'b\n', 'c\n']
  2553. try:
  2554. f.writelines(lines)
  2555. f.close()
  2556. f = CountedInput(test_support.TESTFN)
  2557. for (i, expected) in zip(range(1, 5) + [4], lines + 2 * [""]):
  2558. got = f.readline()
  2559. self.assertEqual(expected, got)
  2560. self.assertEqual(f.lineno, i)
  2561. self.assertEqual(f.ateof, (i > len(lines)))
  2562. f.close()
  2563. finally:
  2564. try:
  2565. f.close()
  2566. except:
  2567. pass
  2568. test_support.unlink(test_support.TESTFN)
  2569. def test_keywords(self):
  2570. # Testing keyword args to basic type constructors ...
  2571. self.assertEqual(int(x=1), 1)
  2572. self.assertEqual(float(x=2), 2.0)
  2573. self.assertEqual(long(x=3), 3L)
  2574. self.assertEqual(complex(imag=42, real=666), complex(666, 42))
  2575. self.assertEqual(str(object=500), '500')
  2576. self.assertEqual(unicode(string='abc', errors='strict'), u'abc')
  2577. self.assertEqual(tuple(sequence=range(3)), (0, 1, 2))
  2578. self.assertEqual(list(sequence=(0, 1, 2)), range(3))
  2579. # note: as of Python 2.3, dict() no longer has an "items" keyword arg
  2580. for constructor in (int, float, long, complex, str, unicode,
  2581. tuple, list, file):
  2582. try:
  2583. constructor(bogus_keyword_arg=1)
  2584. except TypeError:
  2585. pass
  2586. else:
  2587. self.fail("expected TypeError from bogus keyword argument to %r"
  2588. % constructor)
  2589. def test_str_subclass_as_dict_key(self):
  2590. # Testing a str subclass used as dict key ..
  2591. class cistr(str):
  2592. """Sublcass of str that computes __eq__ case-insensitively.
  2593. Also computes a hash code of the string in canonical form.
  2594. """
  2595. def __init__(self, value):
  2596. self.canonical = value.lower()
  2597. self.hashcode = hash(self.canonical)
  2598. def __eq__(self, other):
  2599. if not isinstance(other, cistr):
  2600. other = cistr(other)
  2601. return self.canonical == other.canonical
  2602. def __hash__(self):
  2603. return self.hashcode
  2604. self.assertEqual(cistr('ABC'), 'abc')
  2605. self.assertEqual('aBc', cistr('ABC'))
  2606. self.assertEqual(str(cistr('ABC')), 'ABC')
  2607. d = {cistr('one'): 1, cistr('two'): 2, cistr('tHree'): 3}
  2608. self.assertEqual(d[cistr('one')], 1)
  2609. self.assertEqual(d[cistr('tWo')], 2)
  2610. self.assertEqual(d[cistr('THrEE')], 3)
  2611. self.assertIn(cistr('ONe'), d)
  2612. self.assertEqual(d.get(cistr('thrEE')), 3)
  2613. def test_classic_comparisons(self):
  2614. # Testing classic comparisons...
  2615. class classic:
  2616. pass
  2617. for base in (classic, int, object):
  2618. class C(base):
  2619. def __init__(self, value):
  2620. self.value = int(value)
  2621. def __cmp__(self, other):
  2622. if isinstance(other, C):
  2623. return cmp(self.value, other.value)
  2624. if isinstance(other, int) or isinstance(other, long):
  2625. return cmp(self.value, other)
  2626. return NotImplemented
  2627. __hash__ = None # Silence Py3k warning
  2628. c1 = C(1)
  2629. c2 = C(2)
  2630. c3 = C(3)
  2631. self.assertEqual(c1, 1)
  2632. c = {1: c1, 2: c2, 3: c3}
  2633. for x in 1, 2, 3:
  2634. for y in 1, 2, 3:
  2635. self.assertTrue(cmp(c[x], c[y]) == cmp(x, y), "x=%d, y=%d" % (x, y))
  2636. for op in "<", "<=", "==", "!=", ">", ">=":
  2637. self.assertTrue(eval("c[x] %s c[y]" % op) == eval("x %s y" % op),
  2638. "x=%d, y=%d" % (x, y))
  2639. self.assertTrue(cmp(c[x], y) == cmp(x, y), "x=%d, y=%d" % (x, y))
  2640. self.assertTrue(cmp(x, c[y]) == cmp(x, y), "x=%d, y=%d" % (x, y))
  2641. def test_rich_comparisons(self):
  2642. # Testing rich comparisons...
  2643. class Z(complex):
  2644. pass
  2645. z = Z(1)
  2646. self.assertEqual(z, 1+0j)
  2647. self.assertEqual(1+0j, z)
  2648. class ZZ(complex):
  2649. def __eq__(self, other):
  2650. try:
  2651. return abs(self - other) <= 1e-6
  2652. except:
  2653. return NotImplemented
  2654. __hash__ = None # Silence Py3k warning
  2655. zz = ZZ(1.0000003)
  2656. self.assertEqual(zz, 1+0j)
  2657. self.assertEqual(1+0j, zz)
  2658. class classic:
  2659. pass
  2660. for base in (classic, int, object, list):
  2661. class C(base):
  2662. def __init__(self, value):
  2663. self.value = int(value)
  2664. def __cmp__(self_, other):
  2665. self.fail("shouldn't call __cmp__")
  2666. __hash__ = None # Silence Py3k warning
  2667. def __eq__(self, other):
  2668. if isinstance(other, C):
  2669. return self.value == other.value
  2670. if isinstance(other, int) or isinstance(other, long):
  2671. return self.value == other
  2672. return NotImplemented
  2673. def __ne__(self, other):
  2674. if isinstance(other, C):
  2675. return self.value != other.value
  2676. if isinstance(other, int) or isinstance(other, long):
  2677. return self.value != other
  2678. return NotImplemented
  2679. def __lt__(self, other):
  2680. if isinstance(other, C):
  2681. return self.value < other.value
  2682. if isinstance(other, int) or isinstance(other, long):
  2683. return self.value < other
  2684. return NotImplemented
  2685. def __le__(self, other):
  2686. if isinstance(other, C):
  2687. return self.value <= other.value
  2688. if isinstance(other, int) or isinstance(other, long):
  2689. return self.value <= other
  2690. return NotImplemented
  2691. def __gt__(self, other):
  2692. if isinstance(other, C):
  2693. return self.value > other.value
  2694. if isinstance(other, int) or isinstance(other, long):
  2695. return self.value > other
  2696. return NotImplemented
  2697. def __ge__(self, other):
  2698. if isinstance(other, C):
  2699. return self.value >= other.value
  2700. if isinstance(other, int) or isinstance(other, long):
  2701. return self.value >= other
  2702. return NotImplemented
  2703. c1 = C(1)
  2704. c2 = C(2)
  2705. c3 = C(3)
  2706. self.assertEqual(c1, 1)
  2707. c = {1: c1, 2: c2, 3: c3}
  2708. for x in 1, 2, 3:
  2709. for y in 1, 2, 3:
  2710. for op in "<", "<=", "==", "!=", ">", ">=":
  2711. self.assertTrue(eval("c[x] %s c[y]" % op) == eval("x %s y" % op),
  2712. "x=%d, y=%d" % (x, y))
  2713. self.assertTrue(eval("c[x] %s y" % op) == eval("x %s y" % op),
  2714. "x=%d, y=%d" % (x, y))
  2715. self.assertTrue(eval("x %s c[y]" % op) == eval("x %s y" % op),
  2716. "x=%d, y=%d" % (x, y))
  2717. def test_coercions(self):
  2718. # Testing coercions...
  2719. class I(int): pass
  2720. coerce(I(0), 0)
  2721. coerce(0, I(0))
  2722. class L(long): pass
  2723. coerce(L(0), 0)
  2724. coerce(L(0), 0L)
  2725. coerce(0, L(0))
  2726. coerce(0L, L(0))
  2727. class F(float): pass
  2728. coerce(F(0), 0)
  2729. coerce(F(0), 0L)
  2730. coerce(F(0), 0.)
  2731. coerce(0, F(0))
  2732. coerce(0L, F(0))
  2733. coerce(0., F(0))
  2734. class C(complex): pass
  2735. coerce(C(0), 0)
  2736. coerce(C(0), 0L)
  2737. coerce(C(0), 0.)
  2738. coerce(C(0), 0j)
  2739. coerce(0, C(0))
  2740. coerce(0L, C(0))
  2741. coerce(0., C(0))
  2742. coerce(0j, C(0))
  2743. def test_descrdoc(self):
  2744. # Testing descriptor doc strings...
  2745. def check(descr, what):
  2746. self.assertEqual(descr.__doc__, what)
  2747. check(file.closed, "True if the file is closed") # getset descriptor
  2748. check(file.name, "file name") # member descriptor
  2749. def test_doc_descriptor(self):
  2750. # Testing __doc__ descriptor...
  2751. # SF bug 542984
  2752. class DocDescr(object):
  2753. def __get__(self, object, otype):
  2754. if object:
  2755. object = object.__class__.__name__ + ' instance'
  2756. if otype:
  2757. otype = otype.__name__
  2758. return 'object=%s; type=%s' % (object, otype)
  2759. class OldClass:
  2760. __doc__ = DocDescr()
  2761. class NewClass(object):
  2762. __doc__ = DocDescr()
  2763. self.assertEqual(OldClass.__doc__, 'object=None; type=OldClass')
  2764. self.assertEqual(OldClass().__doc__, 'object=OldClass instance; type=OldClass')
  2765. self.assertEqual(NewClass.__doc__, 'object=None; type=NewClass')
  2766. self.assertEqual(NewClass().__doc__, 'object=NewClass instance; type=NewClass')
  2767. def test_set_class(self):
  2768. # Testing __class__ assignment...
  2769. class C(object): pass
  2770. class D(object): pass
  2771. class E(object): pass
  2772. class F(D, E): pass
  2773. for cls in C, D, E, F:
  2774. for cls2 in C, D, E, F:
  2775. x = cls()
  2776. x.__class__ = cls2
  2777. self.assertTrue(x.__class__ is cls2)
  2778. x.__class__ = cls
  2779. self.assertTrue(x.__class__ is cls)
  2780. def cant(x, C):
  2781. try:
  2782. x.__class__ = C
  2783. except TypeError:
  2784. pass
  2785. else:
  2786. self.fail("shouldn't allow %r.__class__ = %r" % (x, C))
  2787. try:
  2788. delattr(x, "__class__")
  2789. except (TypeError, AttributeError):
  2790. pass
  2791. else:
  2792. self.fail("shouldn't allow del %r.__class__" % x)
  2793. cant(C(), list)
  2794. cant(list(), C)
  2795. cant(C(), 1)
  2796. cant(C(), object)
  2797. cant(object(), list)
  2798. cant(list(), object)
  2799. class Int(int): __slots__ = []
  2800. cant(2, Int)
  2801. cant(Int(), int)
  2802. cant(True, int)
  2803. cant(2, bool)
  2804. o = object()
  2805. cant(o, type(1))
  2806. cant(o, type(None))
  2807. del o
  2808. class G(object):
  2809. __slots__ = ["a", "b"]
  2810. class H(object):
  2811. __slots__ = ["b", "a"]
  2812. try:
  2813. unicode
  2814. except NameError:
  2815. class I(object):
  2816. __slots__ = ["a", "b"]
  2817. else:
  2818. class I(object):
  2819. __slots__ = [unicode("a"), unicode("b")]
  2820. class J(object):
  2821. __slots__ = ["c", "b"]
  2822. class K(object):
  2823. __slots__ = ["a", "b", "d"]
  2824. class L(H):
  2825. __slots__ = ["e"]
  2826. class M(I):
  2827. __slots__ = ["e"]
  2828. class N(J):
  2829. __slots__ = ["__weakref__"]
  2830. class P(J):
  2831. __slots__ = ["__dict__"]
  2832. class Q(J):
  2833. pass
  2834. class R(J):
  2835. __slots__ = ["__dict__", "__weakref__"]
  2836. if test_support.check_impl_detail(pypy=False):
  2837. lst = ((G, H), (G, I), (I, H), (Q, R), (R, Q))
  2838. else:
  2839. # Not supported in pypy: changing the __class__ of an object
  2840. # to another __class__ that just happens to have the same slots.
  2841. # If needed, we can add the feature, but what we'll likely do
  2842. # then is to allow mostly any __class__ assignment, even if the
  2843. # classes have different __slots__, because we it's easier.
  2844. lst = ((Q, R), (R, Q))
  2845. for cls, cls2 in lst:
  2846. x = cls()
  2847. x.a = 1
  2848. x.__class__ = cls2
  2849. self.assertTrue(x.__class__ is cls2,
  2850. "assigning %r as __class__ for %r silently failed" % (cls2, x))
  2851. self.assertEqual(x.a, 1)
  2852. x.__class__ = cls
  2853. self.assertTrue(x.__class__ is cls,
  2854. "assigning %r as __class__ for %r silently failed" % (cls, x))
  2855. self.assertEqual(x.a, 1)
  2856. for cls in G, J, K, L, M, N, P, R, list, Int:
  2857. for cls2 in G, J, K, L, M, N, P, R, list, Int:
  2858. if cls is cls2:
  2859. continue
  2860. cant(cls(), cls2)
  2861. # Issue5283: when __class__ changes in __del__, the wrong
  2862. # type gets DECREF'd.
  2863. class O(object):
  2864. pass
  2865. class A(object):
  2866. def __del__(self):
  2867. self.__class__ = O
  2868. l = [A() for x in range(100)]
  2869. del l
  2870. def test_set_dict(self):
  2871. # Testing __dict__ assignment...
  2872. class C(object): pass
  2873. a = C()
  2874. a.__dict__ = {'b': 1}
  2875. self.assertEqual(a.b, 1)
  2876. def cant(x, dict):
  2877. try:
  2878. x.__dict__ = dict
  2879. except (AttributeError, TypeError):
  2880. pass
  2881. else:
  2882. self.fail("shouldn't allow %r.__dict__ = %r" % (x, dict))
  2883. cant(a, None)
  2884. cant(a, [])
  2885. cant(a, 1)
  2886. del a.__dict__ # Deleting __dict__ is allowed
  2887. class Base(object):
  2888. pass
  2889. def verify_dict_readonly(x):
  2890. """
  2891. x has to be an instance of a class inheriting from Base.
  2892. """
  2893. cant(x, {})
  2894. try:
  2895. del x.__dict__
  2896. except (AttributeError, TypeError):
  2897. pass
  2898. else:
  2899. self.fail("shouldn't allow del %r.__dict__" % x)
  2900. dict_descr = Base.__dict__["__dict__"]
  2901. try:
  2902. dict_descr.__set__(x, {})
  2903. except (AttributeError, TypeError):
  2904. pass
  2905. else:
  2906. self.fail("dict_descr allowed access to %r's dict" % x)
  2907. # Classes don't allow __dict__ assignment and have readonly dicts
  2908. class Meta1(type, Base):
  2909. pass
  2910. class Meta2(Base, type):
  2911. pass
  2912. class D(object):
  2913. __metaclass__ = Meta1
  2914. class E(object):
  2915. __metaclass__ = Meta2
  2916. for cls in C, D, E:
  2917. verify_dict_readonly(cls)
  2918. class_dict = cls.__dict__
  2919. try:
  2920. class_dict["spam"] = "eggs"
  2921. except TypeError:
  2922. pass
  2923. else:
  2924. if test_support.check_impl_detail(pypy=False):
  2925. self.fail("%r's __dict__ can be modified" % cls)
  2926. # Modules also disallow __dict__ assignment
  2927. class Module1(types.ModuleType, Base):
  2928. pass
  2929. class Module2(Base, types.ModuleType):
  2930. pass
  2931. for ModuleType in Module1, Module2:
  2932. mod = ModuleType("spam")
  2933. verify_dict_readonly(mod)
  2934. mod.__dict__["spam"] = "eggs"
  2935. # Exception's __dict__ can be replaced, but not deleted
  2936. # (at least not any more than regular exception's __dict__ can
  2937. # be deleted; on CPython it is not the case, whereas on PyPy they
  2938. # can, just like any other new-style instance's __dict__.)
  2939. def can_delete_dict(e):
  2940. try:
  2941. del e.__dict__
  2942. except (TypeError, AttributeError):
  2943. return False
  2944. else:
  2945. return True
  2946. class Exception1(Exception, Base):
  2947. pass
  2948. class Exception2(Base, Exception):
  2949. pass
  2950. for ExceptionType in Exception, Exception1, Exception2:
  2951. e = ExceptionType()
  2952. e.__dict__ = {"a": 1}
  2953. self.assertEqual(e.a, 1)
  2954. self.assertEqual(can_delete_dict(e), can_delete_dict(ValueError()))
  2955. def test_pickles(self):
  2956. # Testing pickling and copying new-style classes and objects...
  2957. import pickle, cPickle
  2958. def sorteditems(d):
  2959. L = d.items()
  2960. L.sort()
  2961. return L
  2962. global C
  2963. class C(object):
  2964. def __init__(self, a, b):
  2965. super(C, self).__init__()
  2966. self.a = a
  2967. self.b = b
  2968. def __repr__(self):
  2969. return "C(%r, %r)" % (self.a, self.b)
  2970. global C1
  2971. class C1(list):
  2972. def __new__(cls, a, b):
  2973. return super(C1, cls).__new__(cls)
  2974. def __getnewargs__(self):
  2975. return (self.a, self.b)
  2976. def __init__(self, a, b):
  2977. self.a = a
  2978. self.b = b
  2979. def __repr__(self):
  2980. return "C1(%r, %r)<%r>" % (self.a, self.b, list(self))
  2981. global C2
  2982. class C2(int):
  2983. def __new__(cls, a, b, val=0):
  2984. return super(C2, cls).__new__(cls, val)
  2985. def __getnewargs__(self):
  2986. return (self.a, self.b, int(self))
  2987. def __init__(self, a, b, val=0):
  2988. self.a = a
  2989. self.b = b
  2990. def __repr__(self):
  2991. return "C2(%r, %r)<%r>" % (self.a, self.b, int(self))
  2992. global C3
  2993. class C3(object):
  2994. def __init__(self, foo):
  2995. self.foo = foo
  2996. def __getstate__(self):
  2997. return self.foo
  2998. def __setstate__(self, foo):
  2999. self.foo = foo
  3000. global C4classic, C4
  3001. class C4classic: # classic
  3002. pass
  3003. class C4(C4classic, object): # mixed inheritance
  3004. pass
  3005. for p in pickle, cPickle:
  3006. for bin in 0, 1:
  3007. for cls in C, C1, C2:
  3008. s = p.dumps(cls, bin)
  3009. cls2 = p.loads(s)
  3010. self.assertTrue(cls2 is cls)
  3011. a = C1(1, 2); a.append(42); a.append(24)
  3012. b = C2("hello", "world", 42)
  3013. s = p.dumps((a, b), bin)
  3014. x, y = p.loads(s)
  3015. self.assertEqual(x.__class__, a.__class__)
  3016. self.assertEqual(sorteditems(x.__dict__), sorteditems(a.__dict__))
  3017. self.assertEqual(y.__class__, b.__class__)
  3018. self.assertEqual(sorteditems(y.__dict__), sorteditems(b.__dict__))
  3019. self.assertEqual(repr(x), repr(a))
  3020. self.assertEqual(repr(y), repr(b))
  3021. # Test for __getstate__ and __setstate__ on new style class
  3022. u = C3(42)
  3023. s = p.dumps(u, bin)
  3024. v = p.loads(s)
  3025. self.assertEqual(u.__class__, v.__class__)
  3026. self.assertEqual(u.foo, v.foo)
  3027. # Test for picklability of hybrid class
  3028. u = C4()
  3029. u.foo = 42
  3030. s = p.dumps(u, bin)
  3031. v = p.loads(s)
  3032. self.assertEqual(u.__class__, v.__class__)
  3033. self.assertEqual(u.foo, v.foo)
  3034. # Testing copy.deepcopy()
  3035. import copy
  3036. for cls in C, C1, C2:
  3037. cls2 = copy.deepcopy(cls)
  3038. self.assertTrue(cls2 is cls)
  3039. a = C1(1, 2); a.append(42); a.append(24)
  3040. b = C2("hello", "world", 42)
  3041. x, y = copy.deepcopy((a, b))
  3042. self.assertEqual(x.__class__, a.__class__)
  3043. self.assertEqual(sorteditems(x.__dict__), sorteditems(a.__dict__))
  3044. self.assertEqual(y.__class__, b.__class__)
  3045. self.assertEqual(sorteditems(y.__dict__), sorteditems(b.__dict__))
  3046. self.assertEqual(repr(x), repr(a))
  3047. self.assertEqual(repr(y), repr(b))
  3048. def test_pickle_slots(self):
  3049. # Testing pickling of classes with __slots__ ...
  3050. import pickle, cPickle
  3051. # Pickling of classes with __slots__ but without __getstate__ should fail
  3052. global B, C, D, E
  3053. class B(object):
  3054. pass
  3055. for base in [object, B]:
  3056. class C(base):
  3057. __slots__ = ['a']
  3058. class D(C):
  3059. pass
  3060. try:
  3061. pickle.dumps(C())
  3062. except TypeError:
  3063. pass
  3064. else:
  3065. self.fail("should fail: pickle C instance - %s" % base)
  3066. try:
  3067. cPickle.dumps(C())
  3068. except TypeError:
  3069. pass
  3070. else:
  3071. self.fail("should fail: cPickle C instance - %s" % base)
  3072. try:
  3073. pickle.dumps(C())
  3074. except TypeError:
  3075. pass
  3076. else:
  3077. self.fail("should fail: pickle D instance - %s" % base)
  3078. try:
  3079. cPickle.dumps(D())
  3080. except TypeError:
  3081. pass
  3082. else:
  3083. self.fail("should fail: cPickle D instance - %s" % base)
  3084. # Give C a nice generic __getstate__ and __setstate__
  3085. class C(base):
  3086. __slots__ = ['a']
  3087. def __getstate__(self):
  3088. try:
  3089. d = self.__dict__.copy()
  3090. except AttributeError:
  3091. d = {}
  3092. for cls in self.__class__.__mro__:
  3093. for sn in cls.__dict__.get('__slots__', ()):
  3094. try:
  3095. d[sn] = getattr(self, sn)
  3096. except AttributeError:
  3097. pass
  3098. return d
  3099. def __setstate__(self, d):
  3100. for k, v in d.items():
  3101. setattr(self, k, v)
  3102. class D(C):
  3103. pass
  3104. # Now it should work
  3105. x = C()
  3106. y = pickle.loads(pickle.dumps(x))
  3107. self.assertEqual(hasattr(y, 'a'), 0)
  3108. y = cPickle.loads(cPickle.dumps(x))
  3109. self.assertEqual(hasattr(y, 'a'), 0)
  3110. x.a = 42
  3111. y = pickle.loads(pickle.dumps(x))
  3112. self.assertEqual(y.a, 42)
  3113. y = cPickle.loads(cPickle.dumps(x))
  3114. self.assertEqual(y.a, 42)
  3115. x = D()
  3116. x.a = 42
  3117. x.b = 100
  3118. y = pickle.loads(pickle.dumps(x))
  3119. self.assertEqual(y.a + y.b, 142)
  3120. y = cPickle.loads(cPickle.dumps(x))
  3121. self.assertEqual(y.a + y.b, 142)
  3122. # A subclass that adds a slot should also work
  3123. class E(C):
  3124. __slots__ = ['b']
  3125. x = E()
  3126. x.a = 42
  3127. x.b = "foo"
  3128. y = pickle.loads(pickle.dumps(x))
  3129. self.assertEqual(y.a, x.a)
  3130. self.assertEqual(y.b, x.b)
  3131. y = cPickle.loads(cPickle.dumps(x))
  3132. self.assertEqual(y.a, x.a)
  3133. self.assertEqual(y.b, x.b)
  3134. def test_binary_operator_override(self):
  3135. # Testing overrides of binary operations...
  3136. class I(int):
  3137. def __repr__(self):
  3138. return "I(%r)" % int(self)
  3139. def __add__(self, other):
  3140. return I(int(self) + int(other))
  3141. __radd__ = __add__
  3142. def __pow__(self, other, mod=None):
  3143. if mod is None:
  3144. return I(pow(int(self), int(other)))
  3145. else:
  3146. return I(pow(int(self), int(other), int(mod)))
  3147. def __rpow__(self, other, mod=None):
  3148. if mod is None:
  3149. return I(pow(int(other), int(self), mod))
  3150. else:
  3151. return I(pow(int(other), int(self), int(mod)))
  3152. self.assertEqual(repr(I(1) + I(2)), "I(3)")
  3153. self.assertEqual(repr(I(1) + 2), "I(3)")
  3154. self.assertEqual(repr(1 + I(2)), "I(3)")
  3155. self.assertEqual(repr(I(2) ** I(3)), "I(8)")
  3156. self.assertEqual(repr(2 ** I(3)), "I(8)")
  3157. self.assertEqual(repr(I(2) ** 3), "I(8)")
  3158. self.assertEqual(repr(pow(I(2), I(3), I(5))), "I(3)")
  3159. class S(str):
  3160. def __eq__(self, other):
  3161. return self.lower() == other.lower()
  3162. __hash__ = None # Silence Py3k warning
  3163. def test_subclass_propagation(self):
  3164. # Testing propagation of slot functions to subclasses...
  3165. class A(object):
  3166. pass
  3167. class B(A):
  3168. pass
  3169. class C(A):
  3170. pass
  3171. class D(B, C):
  3172. pass
  3173. d = D()
  3174. orig_hash = hash(d) # related to id(d) in platform-dependent ways
  3175. A.__hash__ = lambda self: 42
  3176. self.assertEqual(hash(d), 42)
  3177. C.__hash__ = lambda self: 314
  3178. self.assertEqual(hash(d), 314)
  3179. B.__hash__ = lambda self: 144
  3180. self.assertEqual(hash(d), 144)
  3181. D.__hash__ = lambda self: 100
  3182. self.assertEqual(hash(d), 100)
  3183. D.__hash__ = None
  3184. self.assertRaises(TypeError, hash, d)
  3185. del D.__hash__
  3186. self.assertEqual(hash(d), 144)
  3187. B.__hash__ = None
  3188. self.assertRaises(TypeError, hash, d)
  3189. del B.__hash__
  3190. self.assertEqual(hash(d), 314)
  3191. C.__hash__ = None
  3192. self.assertRaises(TypeError, hash, d)
  3193. del C.__hash__
  3194. self.assertEqual(hash(d), 42)
  3195. A.__hash__ = None
  3196. self.assertRaises(TypeError, hash, d)
  3197. del A.__hash__
  3198. self.assertEqual(hash(d), orig_hash)
  3199. d.foo = 42
  3200. d.bar = 42
  3201. self.assertEqual(d.foo, 42)
  3202. self.assertEqual(d.bar, 42)
  3203. def __getattribute__(self, name):
  3204. if name == "foo":
  3205. return 24
  3206. return object.__getattribute__(self, name)
  3207. A.__getattribute__ = __getattribute__
  3208. self.assertEqual(d.foo, 24)
  3209. self.assertEqual(d.bar, 42)
  3210. def __getattr__(self, name):
  3211. if name in ("spam", "foo", "bar"):
  3212. return "hello"
  3213. raise AttributeError, name
  3214. B.__getattr__ = __getattr__
  3215. self.assertEqual(d.spam, "hello")
  3216. self.assertEqual(d.foo, 24)
  3217. self.assertEqual(d.bar, 42)
  3218. del A.__getattribute__
  3219. self.assertEqual(d.foo, 42)
  3220. del d.foo
  3221. self.assertEqual(d.foo, "hello")
  3222. self.assertEqual(d.bar, 42)
  3223. del B.__getattr__
  3224. try:
  3225. d.foo
  3226. except AttributeError:
  3227. pass
  3228. else:
  3229. self.fail("d.foo should be undefined now")
  3230. # Test a nasty bug in recurse_down_subclasses()
  3231. class A(object):
  3232. pass
  3233. class B(A):
  3234. pass
  3235. del B
  3236. test_support.gc_collect()
  3237. A.__setitem__ = lambda *a: None # crash
  3238. def test_buffer_inheritance(self):
  3239. # Testing that buffer interface is inherited ...
  3240. import binascii
  3241. # SF bug [#470040] ParseTuple t# vs subclasses.
  3242. class MyStr(str):
  3243. pass
  3244. base = 'abc'
  3245. m = MyStr(base)
  3246. # b2a_hex uses the buffer interface to get its argument's value, via
  3247. # PyArg_ParseTuple 't#' code.
  3248. self.assertEqual(binascii.b2a_hex(m), binascii.b2a_hex(base))
  3249. # It's not clear that unicode will continue to support the character
  3250. # buffer interface, and this test will fail if that's taken away.
  3251. class MyUni(unicode):
  3252. pass
  3253. base = u'abc'
  3254. m = MyUni(base)
  3255. self.assertEqual(binascii.b2a_hex(m), binascii.b2a_hex(base))
  3256. class MyInt(int):
  3257. pass
  3258. m = MyInt(42)
  3259. try:
  3260. binascii.b2a_hex(m)
  3261. self.fail('subclass of int should not have a buffer interface')
  3262. except TypeError:
  3263. pass
  3264. def test_str_of_str_subclass(self):
  3265. # Testing __str__ defined in subclass of str ...
  3266. import binascii
  3267. import cStringIO
  3268. class octetstring(str):
  3269. def __str__(self):
  3270. return binascii.b2a_hex(self)
  3271. def __repr__(self):
  3272. return self + " repr"
  3273. o = octetstring('A')
  3274. self.assertEqual(type(o), octetstring)
  3275. self.assertEqual(type(str(o)), str)
  3276. self.assertEqual(type(repr(o)), str)
  3277. self.assertEqual(ord(o), 0x41)
  3278. self.assertEqual(str(o), '41')
  3279. self.assertEqual(repr(o), 'A repr')
  3280. self.assertEqual(o.__str__(), '41')
  3281. self.assertEqual(o.__repr__(), 'A repr')
  3282. capture = cStringIO.StringIO()
  3283. # Calling str() or not exercises different internal paths.
  3284. print >> capture, o
  3285. print >> capture, str(o)
  3286. self.assertEqual(capture.getvalue(), '41\n41\n')
  3287. capture.close()
  3288. def test_keyword_arguments(self):
  3289. # Testing keyword arguments to __init__, __call__...
  3290. def f(a): return a
  3291. self.assertEqual(f.__call__(a=42), 42)
  3292. a = []
  3293. list.__init__(a, sequence=[0, 1, 2])
  3294. self.assertEqual(a, [0, 1, 2])
  3295. def test_recursive_call(self):
  3296. # Testing recursive __call__() by setting to instance of class...
  3297. class A(object):
  3298. pass
  3299. A.__call__ = A()
  3300. try:
  3301. A()()
  3302. except RuntimeError:
  3303. pass
  3304. else:
  3305. self.fail("Recursion limit should have been reached for __call__()")
  3306. def test_delete_hook(self):
  3307. # Testing __del__ hook...
  3308. log = []
  3309. class C(object):
  3310. def __del__(self):
  3311. log.append(1)
  3312. c = C()
  3313. self.assertEqual(log, [])
  3314. del c
  3315. test_support.gc_collect()
  3316. self.assertEqual(log, [1])
  3317. class D(object): pass
  3318. d = D()
  3319. try: del d[0]
  3320. except TypeError: pass
  3321. else: self.fail("invalid del() didn't raise TypeError")
  3322. def test_hash_inheritance(self):
  3323. # Testing hash of mutable subclasses...
  3324. class mydict(dict):
  3325. pass
  3326. d = mydict()
  3327. try:
  3328. hash(d)
  3329. except TypeError:
  3330. pass
  3331. else:
  3332. self.fail("hash() of dict subclass should fail")
  3333. class mylist(list):
  3334. pass
  3335. d = mylist()
  3336. try:
  3337. hash(d)
  3338. except TypeError:
  3339. pass
  3340. else:
  3341. self.fail("hash() of list subclass should fail")
  3342. def test_str_operations(self):
  3343. try: 'a' + 5
  3344. except TypeError: pass
  3345. else: self.fail("'' + 5 doesn't raise TypeError")
  3346. try: ''.split('')
  3347. except ValueError: pass
  3348. else: self.fail("''.split('') doesn't raise ValueError")
  3349. try: ''.join([0])
  3350. except TypeError: pass
  3351. else: self.fail("''.join([0]) doesn't raise TypeError")
  3352. try: ''.rindex('5')
  3353. except ValueError: pass
  3354. else: self.fail("''.rindex('5') doesn't raise ValueError")
  3355. try: '%(n)s' % None
  3356. except TypeError: pass
  3357. else: self.fail("'%(n)s' % None doesn't raise TypeError")
  3358. try: '%(n' % {}
  3359. except ValueError: pass
  3360. else: self.fail("'%(n' % {} '' doesn't raise ValueError")
  3361. try: '%*s' % ('abc')
  3362. except TypeError: pass
  3363. else: self.fail("'%*s' % ('abc') doesn't raise TypeError")
  3364. try: '%*.*s' % ('abc', 5)
  3365. except TypeError: pass
  3366. else: self.fail("'%*.*s' % ('abc', 5) doesn't raise TypeError")
  3367. try: '%s' % (1, 2)
  3368. except TypeError: pass
  3369. else: self.fail("'%s' % (1, 2) doesn't raise TypeError")
  3370. try: '%' % None
  3371. except ValueError: pass
  3372. else: self.fail("'%' % None doesn't raise ValueError")
  3373. self.assertEqual('534253'.isdigit(), 1)
  3374. self.assertEqual('534253x'.isdigit(), 0)
  3375. self.assertEqual('%c' % 5, '\x05')
  3376. self.assertEqual('%c' % '5', '5')
  3377. def test_deepcopy_recursive(self):
  3378. # Testing deepcopy of recursive objects...
  3379. class Node:
  3380. pass
  3381. a = Node()
  3382. b = Node()
  3383. a.b = b
  3384. b.a = a
  3385. z = deepcopy(a) # This blew up before
  3386. def test_unintialized_modules(self):
  3387. # Testing uninitialized module objects...
  3388. from types import ModuleType as M
  3389. m = M.__new__(M)
  3390. str(m)
  3391. self.assertEqual(hasattr(m, "__name__"), 0)
  3392. self.assertEqual(hasattr(m, "__file__"), 0)
  3393. self.assertEqual(hasattr(m, "foo"), 0)
  3394. self.assertFalse(m.__dict__) # None or {} are both reasonable answers
  3395. m.foo = 1
  3396. self.assertEqual(m.__dict__, {"foo": 1})
  3397. def test_funny_new(self):
  3398. # Testing __new__ returning something unexpected...
  3399. class C(object):
  3400. def __new__(cls, arg):
  3401. if isinstance(arg, str): return [1, 2, 3]
  3402. elif isinstance(arg, int): return object.__new__(D)
  3403. else: return object.__new__(cls)
  3404. class D(C):
  3405. def __init__(self, arg):
  3406. self.foo = arg
  3407. self.assertEqual(C("1"), [1, 2, 3])
  3408. self.assertEqual(D("1"), [1, 2, 3])
  3409. d = D(None)
  3410. self.assertEqual(d.foo, None)
  3411. d = C(1)
  3412. self.assertEqual(isinstance(d, D), True)
  3413. self.assertEqual(d.foo, 1)
  3414. d = D(1)
  3415. self.assertEqual(isinstance(d, D), True)
  3416. self.assertEqual(d.foo, 1)
  3417. def test_imul_bug(self):
  3418. # Testing for __imul__ problems...
  3419. # SF bug 544647
  3420. class C(object):
  3421. def __imul__(self, other):
  3422. return (self, other)
  3423. x = C()
  3424. y = x
  3425. y *= 1.0
  3426. self.assertEqual(y, (x, 1.0))
  3427. y = x
  3428. y *= 2
  3429. self.assertEqual(y, (x, 2))
  3430. y = x
  3431. y *= 3L
  3432. self.assertEqual(y, (x, 3L))
  3433. y = x
  3434. y *= 1L<<100
  3435. self.assertEqual(y, (x, 1L<<100))
  3436. y = x
  3437. y *= None
  3438. self.assertEqual(y, (x, None))
  3439. y = x
  3440. y *= "foo"
  3441. self.assertEqual(y, (x, "foo"))
  3442. def test_copy_setstate(self):
  3443. # Testing that copy.*copy() correctly uses __setstate__...
  3444. import copy
  3445. class C(object):
  3446. def __init__(self, foo=None):
  3447. self.foo = foo
  3448. self.__foo = foo
  3449. def setfoo(self, foo=None):
  3450. self.foo = foo
  3451. def getfoo(self):
  3452. return self.__foo
  3453. def __getstate__(self):
  3454. return [self.foo]
  3455. def __setstate__(self_, lst):
  3456. self.assertEqual(len(lst), 1)
  3457. self_.__foo = self_.foo = lst[0]
  3458. a = C(42)
  3459. a.setfoo(24)
  3460. self.assertEqual(a.foo, 24)
  3461. self.assertEqual(a.getfoo(), 42)
  3462. b = copy.copy(a)
  3463. self.assertEqual(b.foo, 24)
  3464. self.assertEqual(b.getfoo(), 24)
  3465. b = copy.deepcopy(a)
  3466. self.assertEqual(b.foo, 24)
  3467. self.assertEqual(b.getfoo(), 24)
  3468. def test_slices(self):
  3469. # Testing cases with slices and overridden __getitem__ ...
  3470. # Strings
  3471. self.assertEqual("hello"[:4], "hell")
  3472. self.assertEqual("hello"[slice(4)], "hell")
  3473. self.assertEqual(str.__getitem__("hello", slice(4)), "hell")
  3474. class S(str):
  3475. def __getitem__(self, x):
  3476. return str.__getitem__(self, x)
  3477. self.assertEqual(S("hello")[:4], "hell")
  3478. self.assertEqual(S("hello")[slice(4)], "hell")
  3479. self.assertEqual(S("hello").__getitem__(slice(4)), "hell")
  3480. # Tuples
  3481. self.assertEqual((1,2,3)[:2], (1,2))
  3482. self.assertEqual((1,2,3)[slice(2)], (1,2))
  3483. self.assertEqual(tuple.__getitem__((1,2,3), slice(2)), (1,2))
  3484. class T(tuple):
  3485. def __getitem__(self, x):
  3486. return tuple.__getitem__(self, x)
  3487. self.assertEqual(T((1,2,3))[:2], (1,2))
  3488. self.assertEqual(T((1,2,3))[slice(2)], (1,2))
  3489. self.assertEqual(T((1,2,3)).__getitem__(slice(2)), (1,2))
  3490. # Lists
  3491. self.assertEqual([1,2,3][:2], [1,2])
  3492. self.assertEqual([1,2,3][slice(2)], [1,2])
  3493. self.assertEqual(list.__getitem__([1,2,3], slice(2)), [1,2])
  3494. class L(list):
  3495. def __getitem__(self, x):
  3496. return list.__getitem__(self, x)
  3497. self.assertEqual(L([1,2,3])[:2], [1,2])
  3498. self.assertEqual(L([1,2,3])[slice(2)], [1,2])
  3499. self.assertEqual(L([1,2,3]).__getitem__(slice(2)), [1,2])
  3500. # Now do lists and __setitem__
  3501. a = L([1,2,3])
  3502. a[slice(1, 3)] = [3,2]
  3503. self.assertEqual(a, [1,3,2])
  3504. a[slice(0, 2, 1)] = [3,1]
  3505. self.assertEqual(a, [3,1,2])
  3506. a.__setitem__(slice(1, 3), [2,1])
  3507. self.assertEqual(a, [3,2,1])
  3508. a.__setitem__(slice(0, 2, 1), [2,3])
  3509. self.assertEqual(a, [2,3,1])
  3510. def test_subtype_resurrection(self):
  3511. # Testing resurrection of new-style instance...
  3512. class C(object):
  3513. container = []
  3514. def __del__(self):
  3515. # resurrect the instance
  3516. C.container.append(self)
  3517. c = C()
  3518. c.attr = 42
  3519. # The most interesting thing here is whether this blows up, due to
  3520. # flawed GC tracking logic in typeobject.c's call_finalizer() (a 2.2.1
  3521. # bug).
  3522. del c
  3523. # If that didn't blow up, it's also interesting to see whether clearing
  3524. # the last container slot works: that will attempt to delete c again,
  3525. # which will cause c to get appended back to the container again
  3526. # "during" the del. (On non-CPython implementations, however, __del__
  3527. # is typically not called again.)
  3528. test_support.gc_collect()
  3529. self.assertEqual(len(C.container), 1)
  3530. del C.container[-1]
  3531. if test_support.check_impl_detail():
  3532. test_support.gc_collect()
  3533. self.assertEqual(len(C.container), 1)
  3534. self.assertEqual(C.container[-1].attr, 42)
  3535. # Make c mortal again, so that the test framework with -l doesn't report
  3536. # it as a leak.
  3537. del C.__del__
  3538. def test_slots_trash(self):
  3539. # Testing slot trash...
  3540. # Deallocating deeply nested slotted trash caused stack overflows
  3541. class trash(object):
  3542. __slots__ = ['x']
  3543. def __init__(self, x):
  3544. self.x = x
  3545. o = None
  3546. for i in xrange(50000):
  3547. o = trash(o)
  3548. del o
  3549. def test_slots_multiple_inheritance(self):
  3550. # SF bug 575229, multiple inheritance w/ slots dumps core
  3551. class A(object):
  3552. __slots__=()
  3553. class B(object):
  3554. pass
  3555. class C(A,B) :
  3556. __slots__=()
  3557. if test_support.check_impl_detail():
  3558. self.assertEqual(C.__basicsize__, B.__basicsize__)
  3559. self.assertTrue(hasattr(C, '__dict__'))
  3560. self.assertTrue(hasattr(C, '__weakref__'))
  3561. C().x = 2
  3562. def test_rmul(self):
  3563. # Testing correct invocation of __rmul__...
  3564. # SF patch 592646
  3565. class C(object):
  3566. def __mul__(self, other):
  3567. return "mul"
  3568. def __rmul__(self, other):
  3569. return "rmul"
  3570. a = C()
  3571. self.assertEqual(a*2, "mul")
  3572. self.assertEqual(a*2.2, "mul")
  3573. self.assertEqual(2*a, "rmul")
  3574. self.assertEqual(2.2*a, "rmul")
  3575. def test_ipow(self):
  3576. # Testing correct invocation of __ipow__...
  3577. # [SF bug 620179]
  3578. class C(object):
  3579. def __ipow__(self, other):
  3580. pass
  3581. a = C()
  3582. a **= 2
  3583. def test_mutable_bases(self):
  3584. # Testing mutable bases...
  3585. # stuff that should work:
  3586. class C(object):
  3587. pass
  3588. class C2(object):
  3589. def __getattribute__(self, attr):
  3590. if attr == 'a':
  3591. return 2
  3592. else:
  3593. return super(C2, self).__getattribute__(attr)
  3594. def meth(self):
  3595. return 1
  3596. class D(C):
  3597. pass
  3598. class E(D):
  3599. pass
  3600. d = D()
  3601. e = E()
  3602. D.__bases__ = (C,)
  3603. D.__bases__ = (C2,)
  3604. self.assertEqual(d.meth(), 1)
  3605. self.assertEqual(e.meth(), 1)
  3606. self.assertEqual(d.a, 2)
  3607. self.assertEqual(e.a, 2)
  3608. self.assertEqual(C2.__subclasses__(), [D])
  3609. try:
  3610. del D.__bases__
  3611. except (TypeError, AttributeError):
  3612. pass
  3613. else:
  3614. self.fail("shouldn't be able to delete .__bases__")
  3615. try:
  3616. D.__bases__ = ()
  3617. except TypeError, msg:
  3618. if str(msg) == "a new-style class can't have only classic bases":
  3619. self.fail("wrong error message for .__bases__ = ()")
  3620. else:
  3621. self.fail("shouldn't be able to set .__bases__ to ()")
  3622. try:
  3623. D.__bases__ = (D,)
  3624. except TypeError:
  3625. pass
  3626. else:
  3627. # actually, we'll have crashed by here...
  3628. self.fail("shouldn't be able to create inheritance cycles")
  3629. try:
  3630. D.__bases__ = (C, C)
  3631. except TypeError:
  3632. pass
  3633. else:
  3634. self.fail("didn't detect repeated base classes")
  3635. try:
  3636. D.__bases__ = (E,)
  3637. except TypeError:
  3638. pass
  3639. else:
  3640. self.fail("shouldn't be able to create inheritance cycles")
  3641. # let's throw a classic class into the mix:
  3642. class Classic:
  3643. def meth2(self):
  3644. return 3
  3645. D.__bases__ = (C, Classic)
  3646. self.assertEqual(d.meth2(), 3)
  3647. self.assertEqual(e.meth2(), 3)
  3648. try:
  3649. d.a
  3650. except AttributeError:
  3651. pass
  3652. else:
  3653. self.fail("attribute should have vanished")
  3654. try:
  3655. D.__bases__ = (Classic,)
  3656. except TypeError:
  3657. pass
  3658. else:
  3659. self.fail("new-style class must have a new-style base")
  3660. def test_builtin_bases(self):
  3661. # Make sure all the builtin types can have their base queried without
  3662. # segfaulting. See issue #5787.
  3663. builtin_types = [tp for tp in __builtin__.__dict__.itervalues()
  3664. if isinstance(tp, type)]
  3665. for tp in builtin_types:
  3666. object.__getattribute__(tp, "__bases__")
  3667. if tp is not object:
  3668. self.assertEqual(len(tp.__bases__), 1, tp)
  3669. class L(list):
  3670. pass
  3671. class C(object):
  3672. pass
  3673. class D(C):
  3674. pass
  3675. try:
  3676. L.__bases__ = (dict,)
  3677. except TypeError:
  3678. pass
  3679. else:
  3680. self.fail("shouldn't turn list subclass into dict subclass")
  3681. try:
  3682. list.__bases__ = (dict,)
  3683. except TypeError:
  3684. pass
  3685. else:
  3686. self.fail("shouldn't be able to assign to list.__bases__")
  3687. try:
  3688. D.__bases__ = (C, list)
  3689. except TypeError:
  3690. pass
  3691. else:
  3692. assert 0, "best_base calculation found wanting"
  3693. def test_mutable_bases_with_failing_mro(self):
  3694. # Testing mutable bases with failing mro...
  3695. class WorkOnce(type):
  3696. def __new__(self, name, bases, ns):
  3697. self.flag = 0
  3698. return super(WorkOnce, self).__new__(WorkOnce, name, bases, ns)
  3699. def mro(self):
  3700. if self.flag > 0:
  3701. raise RuntimeError, "bozo"
  3702. else:
  3703. self.flag += 1
  3704. return type.mro(self)
  3705. class WorkAlways(type):
  3706. def mro(self):
  3707. # this is here to make sure that .mro()s aren't called
  3708. # with an exception set (which was possible at one point).
  3709. # An error message will be printed in a debug build.
  3710. # What's a good way to test for this?
  3711. return type.mro(self)
  3712. class C(object):
  3713. pass
  3714. class C2(object):
  3715. pass
  3716. class D(C):
  3717. pass
  3718. class E(D):
  3719. pass
  3720. class F(D):
  3721. __metaclass__ = WorkOnce
  3722. class G(D):
  3723. __metaclass__ = WorkAlways
  3724. # Immediate subclasses have their mro's adjusted in alphabetical
  3725. # order, so E's will get adjusted before adjusting F's fails. We
  3726. # check here that E's gets restored.
  3727. E_mro_before = E.__mro__
  3728. D_mro_before = D.__mro__
  3729. try:
  3730. D.__bases__ = (C2,)
  3731. except RuntimeError:
  3732. self.assertEqual(E.__mro__, E_mro_before)
  3733. self.assertEqual(D.__mro__, D_mro_before)
  3734. else:
  3735. self.fail("exception not propagated")
  3736. def test_mutable_bases_catch_mro_conflict(self):
  3737. # Testing mutable bases catch mro conflict...
  3738. class A(object):
  3739. pass
  3740. class B(object):
  3741. pass
  3742. class C(A, B):
  3743. pass
  3744. class D(A, B):
  3745. pass
  3746. class E(C, D):
  3747. pass
  3748. try:
  3749. C.__bases__ = (B, A)
  3750. except TypeError:
  3751. pass
  3752. else:
  3753. self.fail("didn't catch MRO conflict")
  3754. def test_mutable_names(self):
  3755. # Testing mutable names...
  3756. class C(object):
  3757. pass
  3758. # C.__module__ could be 'test_descr' or '__main__'
  3759. mod = C.__module__
  3760. C.__name__ = 'D'
  3761. self.assertEqual((C.__module__, C.__name__), (mod, 'D'))
  3762. C.__name__ = 'D.E'
  3763. self.assertEqual((C.__module__, C.__name__), (mod, 'D.E'))
  3764. def test_subclass_right_op(self):
  3765. # Testing correct dispatch of subclass overloading __r<op>__...
  3766. # This code tests various cases where right-dispatch of a subclass
  3767. # should be preferred over left-dispatch of a base class.
  3768. # Case 1: subclass of int; this tests code in abstract.c::binary_op1()
  3769. class B(int):
  3770. def __floordiv__(self, other):
  3771. return "B.__floordiv__"
  3772. def __rfloordiv__(self, other):
  3773. return "B.__rfloordiv__"
  3774. self.assertEqual(B(1) // 1, "B.__floordiv__")
  3775. self.assertEqual(1 // B(1), "B.__rfloordiv__")
  3776. # Case 2: subclass of object; this is just the baseline for case 3
  3777. class C(object):
  3778. def __floordiv__(self, other):
  3779. return "C.__floordiv__"
  3780. def __rfloordiv__(self, other):
  3781. return "C.__rfloordiv__"
  3782. self.assertEqual(C() // 1, "C.__floordiv__")
  3783. self.assertEqual(1 // C(), "C.__rfloordiv__")
  3784. # Case 3: subclass of new-style class; here it gets interesting
  3785. class D(C):
  3786. def __floordiv__(self, other):
  3787. return "D.__floordiv__"
  3788. def __rfloordiv__(self, other):
  3789. return "D.__rfloordiv__"
  3790. self.assertEqual(D() // C(), "D.__floordiv__")
  3791. self.assertEqual(C() // D(), "D.__rfloordiv__")
  3792. # Case 4: this didn't work right in 2.2.2 and 2.3a1
  3793. class E(C):
  3794. pass
  3795. self.assertEqual(E.__rfloordiv__, C.__rfloordiv__)
  3796. self.assertEqual(E() // 1, "C.__floordiv__")
  3797. self.assertEqual(1 // E(), "C.__rfloordiv__")
  3798. self.assertEqual(E() // C(), "C.__floordiv__")
  3799. self.assertEqual(C() // E(), "C.__floordiv__") # This one would fail
  3800. @test_support.impl_detail("testing an internal kind of method object")
  3801. def test_meth_class_get(self):
  3802. # Testing __get__ method of METH_CLASS C methods...
  3803. # Full coverage of descrobject.c::classmethod_get()
  3804. # Baseline
  3805. arg = [1, 2, 3]
  3806. res = {1: None, 2: None, 3: None}
  3807. self.assertEqual(dict.fromkeys(arg), res)
  3808. self.assertEqual({}.fromkeys(arg), res)
  3809. # Now get the descriptor
  3810. descr = dict.__dict__["fromkeys"]
  3811. # More baseline using the descriptor directly
  3812. self.assertEqual(descr.__get__(None, dict)(arg), res)
  3813. self.assertEqual(descr.__get__({})(arg), res)
  3814. # Now check various error cases
  3815. try:
  3816. descr.__get__(None, None)
  3817. except TypeError:
  3818. pass
  3819. else:
  3820. self.fail("shouldn't have allowed descr.__get__(None, None)")
  3821. try:
  3822. descr.__get__(42)
  3823. except TypeError:
  3824. pass
  3825. else:
  3826. self.fail("shouldn't have allowed descr.__get__(42)")
  3827. try:
  3828. descr.__get__(None, 42)
  3829. except TypeError:
  3830. pass
  3831. else:
  3832. self.fail("shouldn't have allowed descr.__get__(None, 42)")
  3833. try:
  3834. descr.__get__(None, int)
  3835. except TypeError:
  3836. pass
  3837. else:
  3838. self.fail("shouldn't have allowed descr.__get__(None, int)")
  3839. def test_isinst_isclass(self):
  3840. # Testing proxy isinstance() and isclass()...
  3841. class Proxy(object):
  3842. def __init__(self, obj):
  3843. self.__obj = obj
  3844. def __getattribute__(self, name):
  3845. if name.startswith("_Proxy__"):
  3846. return object.__getattribute__(self, name)
  3847. else:
  3848. return getattr(self.__obj, name)
  3849. # Test with a classic class
  3850. class C:
  3851. pass
  3852. a = C()
  3853. pa = Proxy(a)
  3854. self.assertIsInstance(a, C) # Baseline
  3855. self.assertIsInstance(pa, C) # Test
  3856. # Test with a classic subclass
  3857. class D(C):
  3858. pass
  3859. a = D()
  3860. pa = Proxy(a)
  3861. self.assertIsInstance(a, C) # Baseline
  3862. self.assertIsInstance(pa, C) # Test
  3863. # Test with a new-style class
  3864. class C(object):
  3865. pass
  3866. a = C()
  3867. pa = Proxy(a)
  3868. self.assertIsInstance(a, C) # Baseline
  3869. self.assertIsInstance(pa, C) # Test
  3870. # Test with a new-style subclass
  3871. class D(C):
  3872. pass
  3873. a = D()
  3874. pa = Proxy(a)
  3875. self.assertIsInstance(a, C) # Baseline
  3876. self.assertIsInstance(pa, C) # Test
  3877. def test_proxy_super(self):
  3878. # Testing super() for a proxy object...
  3879. class Proxy(object):
  3880. def __init__(self, obj):
  3881. self.__obj = obj
  3882. def __getattribute__(self, name):
  3883. if name.startswith("_Proxy__"):
  3884. return object.__getattribute__(self, name)
  3885. else:
  3886. return getattr(self.__obj, name)
  3887. class B(object):
  3888. def f(self):
  3889. return "B.f"
  3890. class C(B):
  3891. def f(self):
  3892. return super(C, self).f() + "->C.f"
  3893. obj = C()
  3894. p = Proxy(obj)
  3895. self.assertEqual(C.__dict__["f"](p), "B.f->C.f")
  3896. def test_carloverre(self):
  3897. # Testing prohibition of Carlo Verre's hack...
  3898. try:
  3899. object.__setattr__(str, "foo", 42)
  3900. except TypeError:
  3901. pass
  3902. else:
  3903. self.fail("Carlo Verre __setattr__ succeeded!")
  3904. try:
  3905. object.__delattr__(str, "lower")
  3906. except TypeError:
  3907. pass
  3908. else:
  3909. self.fail("Carlo Verre __delattr__ succeeded!")
  3910. def test_weakref_segfault(self):
  3911. # Testing weakref segfault...
  3912. # SF 742911
  3913. import weakref
  3914. class Provoker:
  3915. def __init__(self, referrent):
  3916. self.ref = weakref.ref(referrent)
  3917. def __del__(self):
  3918. x = self.ref()
  3919. class Oops(object):
  3920. pass
  3921. o = Oops()
  3922. o.whatever = Provoker(o)
  3923. del o
  3924. def test_wrapper_segfault(self):
  3925. # SF 927248: deeply nested wrappers could cause stack overflow
  3926. f = lambda:None
  3927. for i in xrange(1000000):
  3928. f = f.__call__
  3929. f = None
  3930. def test_file_fault(self):
  3931. # Testing sys.stdout is changed in getattr...
  3932. test_stdout = sys.stdout
  3933. class StdoutGuard:
  3934. def __getattr__(self, attr):
  3935. sys.stdout = sys.__stdout__
  3936. raise RuntimeError("Premature access to sys.stdout.%s" % attr)
  3937. sys.stdout = StdoutGuard()
  3938. try:
  3939. print "Oops!"
  3940. except RuntimeError:
  3941. pass
  3942. finally:
  3943. sys.stdout = test_stdout
  3944. def test_vicious_descriptor_nonsense(self):
  3945. # Testing vicious_descriptor_nonsense...
  3946. # A potential segfault spotted by Thomas Wouters in mail to
  3947. # python-dev 2003-04-17, turned into an example & fixed by Michael
  3948. # Hudson just less than four months later...
  3949. class Evil(object):
  3950. def __hash__(self):
  3951. return hash('attr')
  3952. def __eq__(self, other):
  3953. del C.attr
  3954. return 0
  3955. class Descr(object):
  3956. def __get__(self, ob, type=None):
  3957. return 1
  3958. class C(object):
  3959. attr = Descr()
  3960. c = C()
  3961. c.__dict__[Evil()] = 0
  3962. self.assertEqual(c.attr, 1)
  3963. # this makes a crash more likely:
  3964. test_support.gc_collect()
  3965. self.assertEqual(hasattr(c, 'attr'), False)
  3966. def test_init(self):
  3967. # SF 1155938
  3968. class Foo(object):
  3969. def __init__(self):
  3970. return 10
  3971. try:
  3972. Foo()
  3973. except TypeError:
  3974. pass
  3975. else:
  3976. self.fail("did not test __init__() for None return")
  3977. def test_method_wrapper(self):
  3978. # Testing method-wrapper objects...
  3979. # <type 'method-wrapper'> did not support any reflection before 2.5
  3980. l = []
  3981. self.assertEqual(l.__add__, l.__add__)
  3982. self.assertEqual(l.__add__, [].__add__)
  3983. self.assertTrue(l.__add__ != [5].__add__)
  3984. self.assertTrue(l.__add__ != l.__mul__)
  3985. self.assertTrue(l.__add__.__name__ == '__add__')
  3986. self.assertTrue(l.__add__.__self__ is l)
  3987. if hasattr(l.__add__, '__objclass__'): # CPython
  3988. self.assertTrue(l.__add__.__objclass__ is list)
  3989. else: # PyPy
  3990. self.assertTrue(l.__add__.im_class is list)
  3991. self.assertEqual(l.__add__.__doc__, list.__add__.__doc__)
  3992. try:
  3993. hash(l.__add__)
  3994. except TypeError:
  3995. pass
  3996. else:
  3997. self.fail("no TypeError from hash([].__add__)")
  3998. t = ()
  3999. t += (7,)
  4000. self.assertEqual(t.__add__, (7,).__add__)
  4001. self.assertEqual(hash(t.__add__), hash((7,).__add__))
  4002. def test_not_implemented(self):
  4003. # Testing NotImplemented...
  4004. # all binary methods should be able to return a NotImplemented
  4005. import operator
  4006. def specialmethod(self, other):
  4007. return NotImplemented
  4008. def check(expr, x, y):
  4009. try:
  4010. exec expr in {'x': x, 'y': y, 'operator': operator}
  4011. except TypeError:
  4012. pass
  4013. else:
  4014. self.fail("no TypeError from %r" % (expr,))
  4015. N1 = sys.maxint + 1L # might trigger OverflowErrors instead of
  4016. # TypeErrors
  4017. N2 = sys.maxint # if sizeof(int) < sizeof(long), might trigger
  4018. # ValueErrors instead of TypeErrors
  4019. for metaclass in [type, types.ClassType]:
  4020. for name, expr, iexpr in [
  4021. ('__add__', 'x + y', 'x += y'),
  4022. ('__sub__', 'x - y', 'x -= y'),
  4023. ('__mul__', 'x * y', 'x *= y'),
  4024. ('__truediv__', 'operator.truediv(x, y)', None),
  4025. ('__floordiv__', 'operator.floordiv(x, y)', None),
  4026. ('__div__', 'x / y', 'x /= y'),
  4027. ('__mod__', 'x % y', 'x %= y'),
  4028. ('__divmod__', 'divmod(x, y)', None),
  4029. ('__pow__', 'x ** y', 'x **= y'),
  4030. ('__lshift__', 'x << y', 'x <<= y'),
  4031. ('__rshift__', 'x >> y', 'x >>= y'),
  4032. ('__and__', 'x & y', 'x &= y'),
  4033. ('__or__', 'x | y', 'x |= y'),
  4034. ('__xor__', 'x ^ y', 'x ^= y'),
  4035. ('__coerce__', 'coerce(x, y)', None)]:
  4036. if name == '__coerce__':
  4037. rname = name
  4038. else:
  4039. rname = '__r' + name[2:]
  4040. A = metaclass('A', (), {name: specialmethod})
  4041. B = metaclass('B', (), {rname: specialmethod})
  4042. a = A()
  4043. b = B()
  4044. check(expr, a, a)
  4045. check(expr, a, b)
  4046. check(expr, b, a)
  4047. check(expr, b, b)
  4048. check(expr, a, N1)
  4049. check(expr, a, N2)
  4050. check(expr, N1, b)
  4051. check(expr, N2, b)
  4052. if iexpr:
  4053. check(iexpr, a, a)
  4054. check(iexpr, a, b)
  4055. check(iexpr, b, a)
  4056. check(iexpr, b, b)
  4057. check(iexpr, a, N1)
  4058. check(iexpr, a, N2)
  4059. iname = '__i' + name[2:]
  4060. C = metaclass('C', (), {iname: specialmethod})
  4061. c = C()
  4062. check(iexpr, c, a)
  4063. check(iexpr, c, b)
  4064. check(iexpr, c, N1)
  4065. check(iexpr, c, N2)
  4066. def test_assign_slice(self):
  4067. # ceval.c's assign_slice used to check for
  4068. # tp->tp_as_sequence->sq_slice instead of
  4069. # tp->tp_as_sequence->sq_ass_slice
  4070. class C(object):
  4071. def __setslice__(self, start, stop, value):
  4072. self.value = value
  4073. c = C()
  4074. c[1:2] = 3
  4075. self.assertEqual(c.value, 3)
  4076. def test_set_and_no_get(self):
  4077. # See
  4078. # http://mail.python.org/pipermail/python-dev/2010-January/095637.html
  4079. class Descr(object):
  4080. def __init__(self, name):
  4081. self.name = name
  4082. def __set__(self, obj, value):
  4083. obj.__dict__[self.name] = value
  4084. descr = Descr("a")
  4085. class X(object):
  4086. a = descr
  4087. x = X()
  4088. self.assertIs(x.a, descr)
  4089. x.a = 42
  4090. self.assertEqual(x.a, 42)
  4091. # Also check type_getattro for correctness.
  4092. class Meta(type):
  4093. pass
  4094. class X(object):
  4095. __metaclass__ = Meta
  4096. X.a = 42
  4097. Meta.a = Descr("a")
  4098. self.assertEqual(X.a, 42)
  4099. def test_getattr_hooks(self):
  4100. # issue 4230
  4101. class Descriptor(object):
  4102. counter = 0
  4103. def __get__(self, obj, objtype=None):
  4104. def getter(name):
  4105. self.counter += 1
  4106. raise AttributeError(name)
  4107. return getter
  4108. descr = Descriptor()
  4109. class A(object):
  4110. __getattribute__ = descr
  4111. class B(object):
  4112. __getattr__ = descr
  4113. class C(object):
  4114. __getattribute__ = descr
  4115. __getattr__ = descr
  4116. self.assertRaises(AttributeError, getattr, A(), "attr")
  4117. self.assertEqual(descr.counter, 1)
  4118. self.assertRaises(AttributeError, getattr, B(), "attr")
  4119. self.assertEqual(descr.counter, 2)
  4120. self.assertRaises(AttributeError, getattr, C(), "attr")
  4121. self.assertEqual(descr.counter, 4)
  4122. import gc
  4123. class EvilGetattribute(object):
  4124. # This used to segfault
  4125. def __getattr__(self, name):
  4126. raise AttributeError(name)
  4127. def __getattribute__(self, name):
  4128. del EvilGetattribute.__getattr__
  4129. for i in range(5):
  4130. gc.collect()
  4131. raise AttributeError(name)
  4132. self.assertRaises(AttributeError, getattr, EvilGetattribute(), "attr")
  4133. def test_abstractmethods(self):
  4134. # type pretends not to have __abstractmethods__.
  4135. self.assertRaises(AttributeError, getattr, type, "__abstractmethods__")
  4136. class meta(type):
  4137. pass
  4138. self.assertRaises(AttributeError, getattr, meta, "__abstractmethods__")
  4139. class X(object):
  4140. pass
  4141. with self.assertRaises(AttributeError):
  4142. del X.__abstractmethods__
  4143. def test_proxy_call(self):
  4144. class FakeStr(object):
  4145. __class__ = str
  4146. fake_str = FakeStr()
  4147. # isinstance() reads __class__ on new style classes
  4148. self.assertTrue(isinstance(fake_str, str))
  4149. # call a method descriptor
  4150. with self.assertRaises(TypeError):
  4151. str.split(fake_str)
  4152. # call a slot wrapper descriptor
  4153. try:
  4154. r = str.__add__(fake_str, "abc")
  4155. except TypeError:
  4156. pass
  4157. else:
  4158. self.assertEqual(r, NotImplemented)
  4159. class DictProxyTests(unittest.TestCase):
  4160. def setUp(self):
  4161. class C(object):
  4162. def meth(self):
  4163. pass
  4164. self.C = C
  4165. def test_iter_keys(self):
  4166. # Testing dict-proxy iterkeys...
  4167. keys = [ key for key in self.C.__dict__.iterkeys() ]
  4168. keys.sort()
  4169. self.assertEqual(keys, ['__dict__', '__doc__', '__module__',
  4170. '__weakref__', 'meth'])
  4171. def test_iter_values(self):
  4172. # Testing dict-proxy itervalues...
  4173. values = [ values for values in self.C.__dict__.itervalues() ]
  4174. self.assertEqual(len(values), 5)
  4175. def test_iter_items(self):
  4176. # Testing dict-proxy iteritems...
  4177. keys = [ key for (key, value) in self.C.__dict__.iteritems() ]
  4178. keys.sort()
  4179. self.assertEqual(keys, ['__dict__', '__doc__', '__module__',
  4180. '__weakref__', 'meth'])
  4181. def test_dict_type_with_metaclass(self):
  4182. # Testing type of __dict__ when __metaclass__ set...
  4183. class B(object):
  4184. pass
  4185. class M(type):
  4186. pass
  4187. class C:
  4188. # In 2.3a1, C.__dict__ was a real dict rather than a dict proxy
  4189. __metaclass__ = M
  4190. self.assertEqual(type(C.__dict__), type(B.__dict__))
  4191. class PTypesLongInitTest(unittest.TestCase):
  4192. # This is in its own TestCase so that it can be run before any other tests.
  4193. def test_pytype_long_ready(self):
  4194. # Testing SF bug 551412 ...
  4195. # This dumps core when SF bug 551412 isn't fixed --
  4196. # but only when test_descr.py is run separately.
  4197. # (That can't be helped -- as soon as PyType_Ready()
  4198. # is called for PyLong_Type, the bug is gone.)
  4199. class UserLong(object):
  4200. def __pow__(self, *args):
  4201. pass
  4202. try:
  4203. pow(0L, UserLong(), 0L)
  4204. except:
  4205. pass
  4206. # Another segfault only when run early
  4207. # (before PyType_Ready(tuple) is called)
  4208. type.mro(tuple)
  4209. def test_main():
  4210. deprecations = [(r'complex divmod\(\), // and % are deprecated$',
  4211. DeprecationWarning)]
  4212. if sys.py3kwarning:
  4213. deprecations += [
  4214. ("classic (int|long) division", DeprecationWarning),
  4215. ("coerce.. not supported", DeprecationWarning),
  4216. (".+__(get|set|del)slice__ has been removed", DeprecationWarning)]
  4217. with test_support.check_warnings(*deprecations):
  4218. # Run all local test cases, with PTypesLongInitTest first.
  4219. test_support.run_unittest(PTypesLongInitTest, OperatorsTest,
  4220. ClassPropertiesAndMethods, DictProxyTests)
  4221. if __name__ == "__main__":
  4222. test_main()