PageRenderTime 63ms CodeModel.GetById 22ms RepoModel.GetById 1ms app.codeStats 0ms

/Lib/test/test_set.py

http://unladen-swallow.googlecode.com/
Python | 1747 lines | 1527 code | 175 blank | 45 comment | 61 complexity | ad0b3384ec755c2d1a7f18aa4b3e607c MD5 | raw file
Possible License(s): 0BSD, BSD-3-Clause
  1. import unittest
  2. from test import test_support
  3. import gc
  4. import weakref
  5. import operator
  6. import copy
  7. import pickle
  8. import os
  9. from random import randrange, shuffle
  10. import sys
  11. import collections
  12. class PassThru(Exception):
  13. pass
  14. def check_pass_thru():
  15. raise PassThru
  16. yield 1
  17. class BadCmp:
  18. def __hash__(self):
  19. return 1
  20. def __cmp__(self, other):
  21. raise RuntimeError
  22. class ReprWrapper:
  23. 'Used to test self-referential repr() calls'
  24. def __repr__(self):
  25. return repr(self.value)
  26. class HashCountingInt(int):
  27. 'int-like object that counts the number of times __hash__ is called'
  28. def __init__(self, *args):
  29. self.hash_count = 0
  30. def __hash__(self):
  31. self.hash_count += 1
  32. return int.__hash__(self)
  33. class TestJointOps(unittest.TestCase):
  34. # Tests common to both set and frozenset
  35. def setUp(self):
  36. self.word = word = 'simsalabim'
  37. self.otherword = 'madagascar'
  38. self.letters = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
  39. self.s = self.thetype(word)
  40. self.d = dict.fromkeys(word)
  41. def test_new_or_init(self):
  42. self.assertRaises(TypeError, self.thetype, [], 2)
  43. def test_uniquification(self):
  44. actual = sorted(self.s)
  45. expected = sorted(self.d)
  46. self.assertEqual(actual, expected)
  47. self.assertRaises(PassThru, self.thetype, check_pass_thru())
  48. self.assertRaises(TypeError, self.thetype, [[]])
  49. def test_len(self):
  50. self.assertEqual(len(self.s), len(self.d))
  51. def test_contains(self):
  52. for c in self.letters:
  53. self.assertEqual(c in self.s, c in self.d)
  54. self.assertRaises(TypeError, self.s.__contains__, [[]])
  55. s = self.thetype([frozenset(self.letters)])
  56. self.assert_(self.thetype(self.letters) in s)
  57. def test_union(self):
  58. u = self.s.union(self.otherword)
  59. for c in self.letters:
  60. self.assertEqual(c in u, c in self.d or c in self.otherword)
  61. self.assertEqual(self.s, self.thetype(self.word))
  62. self.assertEqual(type(u), self.thetype)
  63. self.assertRaises(PassThru, self.s.union, check_pass_thru())
  64. self.assertRaises(TypeError, self.s.union, [[]])
  65. for C in set, frozenset, dict.fromkeys, str, unicode, list, tuple:
  66. self.assertEqual(self.thetype('abcba').union(C('cdc')), set('abcd'))
  67. self.assertEqual(self.thetype('abcba').union(C('efgfe')), set('abcefg'))
  68. self.assertEqual(self.thetype('abcba').union(C('ccb')), set('abc'))
  69. self.assertEqual(self.thetype('abcba').union(C('ef')), set('abcef'))
  70. self.assertEqual(self.thetype('abcba').union(C('ef'), C('fg')), set('abcefg'))
  71. # Issue #6573
  72. x = self.thetype()
  73. self.assertEqual(x.union(set([1]), x, set([2])), self.thetype([1, 2]))
  74. def test_or(self):
  75. i = self.s.union(self.otherword)
  76. self.assertEqual(self.s | set(self.otherword), i)
  77. self.assertEqual(self.s | frozenset(self.otherword), i)
  78. try:
  79. self.s | self.otherword
  80. except TypeError:
  81. pass
  82. else:
  83. self.fail("s|t did not screen-out general iterables")
  84. def test_intersection(self):
  85. i = self.s.intersection(self.otherword)
  86. for c in self.letters:
  87. self.assertEqual(c in i, c in self.d and c in self.otherword)
  88. self.assertEqual(self.s, self.thetype(self.word))
  89. self.assertEqual(type(i), self.thetype)
  90. self.assertRaises(PassThru, self.s.intersection, check_pass_thru())
  91. for C in set, frozenset, dict.fromkeys, str, unicode, list, tuple:
  92. self.assertEqual(self.thetype('abcba').intersection(C('cdc')), set('cc'))
  93. self.assertEqual(self.thetype('abcba').intersection(C('efgfe')), set(''))
  94. self.assertEqual(self.thetype('abcba').intersection(C('ccb')), set('bc'))
  95. self.assertEqual(self.thetype('abcba').intersection(C('ef')), set(''))
  96. self.assertEqual(self.thetype('abcba').intersection(C('cbcf'), C('bag')), set('b'))
  97. s = self.thetype('abcba')
  98. z = s.intersection()
  99. if self.thetype == frozenset():
  100. self.assertEqual(id(s), id(z))
  101. else:
  102. self.assertNotEqual(id(s), id(z))
  103. def test_isdisjoint(self):
  104. def f(s1, s2):
  105. 'Pure python equivalent of isdisjoint()'
  106. return not set(s1).intersection(s2)
  107. for larg in '', 'a', 'ab', 'abc', 'ababac', 'cdc', 'cc', 'efgfe', 'ccb', 'ef':
  108. s1 = self.thetype(larg)
  109. for rarg in '', 'a', 'ab', 'abc', 'ababac', 'cdc', 'cc', 'efgfe', 'ccb', 'ef':
  110. for C in set, frozenset, dict.fromkeys, str, unicode, list, tuple:
  111. s2 = C(rarg)
  112. actual = s1.isdisjoint(s2)
  113. expected = f(s1, s2)
  114. self.assertEqual(actual, expected)
  115. self.assert_(actual is True or actual is False)
  116. def test_and(self):
  117. i = self.s.intersection(self.otherword)
  118. self.assertEqual(self.s & set(self.otherword), i)
  119. self.assertEqual(self.s & frozenset(self.otherword), i)
  120. try:
  121. self.s & self.otherword
  122. except TypeError:
  123. pass
  124. else:
  125. self.fail("s&t did not screen-out general iterables")
  126. def test_difference(self):
  127. i = self.s.difference(self.otherword)
  128. for c in self.letters:
  129. self.assertEqual(c in i, c in self.d and c not in self.otherword)
  130. self.assertEqual(self.s, self.thetype(self.word))
  131. self.assertEqual(type(i), self.thetype)
  132. self.assertRaises(PassThru, self.s.difference, check_pass_thru())
  133. self.assertRaises(TypeError, self.s.difference, [[]])
  134. for C in set, frozenset, dict.fromkeys, str, unicode, list, tuple:
  135. self.assertEqual(self.thetype('abcba').difference(C('cdc')), set('ab'))
  136. self.assertEqual(self.thetype('abcba').difference(C('efgfe')), set('abc'))
  137. self.assertEqual(self.thetype('abcba').difference(C('ccb')), set('a'))
  138. self.assertEqual(self.thetype('abcba').difference(C('ef')), set('abc'))
  139. self.assertEqual(self.thetype('abcba').difference(), set('abc'))
  140. self.assertEqual(self.thetype('abcba').difference(C('a'), C('b')), set('c'))
  141. def test_sub(self):
  142. i = self.s.difference(self.otherword)
  143. self.assertEqual(self.s - set(self.otherword), i)
  144. self.assertEqual(self.s - frozenset(self.otherword), i)
  145. try:
  146. self.s - self.otherword
  147. except TypeError:
  148. pass
  149. else:
  150. self.fail("s-t did not screen-out general iterables")
  151. def test_symmetric_difference(self):
  152. i = self.s.symmetric_difference(self.otherword)
  153. for c in self.letters:
  154. self.assertEqual(c in i, (c in self.d) ^ (c in self.otherword))
  155. self.assertEqual(self.s, self.thetype(self.word))
  156. self.assertEqual(type(i), self.thetype)
  157. self.assertRaises(PassThru, self.s.symmetric_difference, check_pass_thru())
  158. self.assertRaises(TypeError, self.s.symmetric_difference, [[]])
  159. for C in set, frozenset, dict.fromkeys, str, unicode, list, tuple:
  160. self.assertEqual(self.thetype('abcba').symmetric_difference(C('cdc')), set('abd'))
  161. self.assertEqual(self.thetype('abcba').symmetric_difference(C('efgfe')), set('abcefg'))
  162. self.assertEqual(self.thetype('abcba').symmetric_difference(C('ccb')), set('a'))
  163. self.assertEqual(self.thetype('abcba').symmetric_difference(C('ef')), set('abcef'))
  164. def test_xor(self):
  165. i = self.s.symmetric_difference(self.otherword)
  166. self.assertEqual(self.s ^ set(self.otherword), i)
  167. self.assertEqual(self.s ^ frozenset(self.otherword), i)
  168. try:
  169. self.s ^ self.otherword
  170. except TypeError:
  171. pass
  172. else:
  173. self.fail("s^t did not screen-out general iterables")
  174. def test_equality(self):
  175. self.assertEqual(self.s, set(self.word))
  176. self.assertEqual(self.s, frozenset(self.word))
  177. self.assertEqual(self.s == self.word, False)
  178. self.assertNotEqual(self.s, set(self.otherword))
  179. self.assertNotEqual(self.s, frozenset(self.otherword))
  180. self.assertEqual(self.s != self.word, True)
  181. def test_setOfFrozensets(self):
  182. t = map(frozenset, ['abcdef', 'bcd', 'bdcb', 'fed', 'fedccba'])
  183. s = self.thetype(t)
  184. self.assertEqual(len(s), 3)
  185. def test_compare(self):
  186. self.assertRaises(TypeError, self.s.__cmp__, self.s)
  187. def test_sub_and_super(self):
  188. p, q, r = map(self.thetype, ['ab', 'abcde', 'def'])
  189. self.assert_(p < q)
  190. self.assert_(p <= q)
  191. self.assert_(q <= q)
  192. self.assert_(q > p)
  193. self.assert_(q >= p)
  194. self.failIf(q < r)
  195. self.failIf(q <= r)
  196. self.failIf(q > r)
  197. self.failIf(q >= r)
  198. self.assert_(set('a').issubset('abc'))
  199. self.assert_(set('abc').issuperset('a'))
  200. self.failIf(set('a').issubset('cbs'))
  201. self.failIf(set('cbs').issuperset('a'))
  202. def test_pickling(self):
  203. for i in range(pickle.HIGHEST_PROTOCOL + 1):
  204. p = pickle.dumps(self.s, i)
  205. dup = pickle.loads(p)
  206. self.assertEqual(self.s, dup, "%s != %s" % (self.s, dup))
  207. if type(self.s) not in (set, frozenset):
  208. self.s.x = 10
  209. p = pickle.dumps(self.s)
  210. dup = pickle.loads(p)
  211. self.assertEqual(self.s.x, dup.x)
  212. def test_deepcopy(self):
  213. class Tracer:
  214. def __init__(self, value):
  215. self.value = value
  216. def __hash__(self):
  217. return self.value
  218. def __deepcopy__(self, memo=None):
  219. return Tracer(self.value + 1)
  220. t = Tracer(10)
  221. s = self.thetype([t])
  222. dup = copy.deepcopy(s)
  223. self.assertNotEqual(id(s), id(dup))
  224. for elem in dup:
  225. newt = elem
  226. self.assertNotEqual(id(t), id(newt))
  227. self.assertEqual(t.value + 1, newt.value)
  228. def test_gc(self):
  229. # Create a nest of cycles to exercise overall ref count check
  230. class A:
  231. pass
  232. s = set(A() for i in xrange(1000))
  233. for elem in s:
  234. elem.cycle = s
  235. elem.sub = elem
  236. elem.set = set([elem])
  237. def test_subclass_with_custom_hash(self):
  238. # Bug #1257731
  239. class H(self.thetype):
  240. def __hash__(self):
  241. return int(id(self) & 0x7fffffff)
  242. s=H()
  243. f=set()
  244. f.add(s)
  245. self.assert_(s in f)
  246. f.remove(s)
  247. f.add(s)
  248. f.discard(s)
  249. def test_badcmp(self):
  250. s = self.thetype([BadCmp()])
  251. # Detect comparison errors during insertion and lookup
  252. self.assertRaises(RuntimeError, self.thetype, [BadCmp(), BadCmp()])
  253. self.assertRaises(RuntimeError, s.__contains__, BadCmp())
  254. # Detect errors during mutating operations
  255. if hasattr(s, 'add'):
  256. self.assertRaises(RuntimeError, s.add, BadCmp())
  257. self.assertRaises(RuntimeError, s.discard, BadCmp())
  258. self.assertRaises(RuntimeError, s.remove, BadCmp())
  259. def test_cyclical_repr(self):
  260. w = ReprWrapper()
  261. s = self.thetype([w])
  262. w.value = s
  263. name = repr(s).partition('(')[0] # strip class name from repr string
  264. self.assertEqual(repr(s), '%s([%s(...)])' % (name, name))
  265. def test_cyclical_print(self):
  266. w = ReprWrapper()
  267. s = self.thetype([w])
  268. w.value = s
  269. fo = open(test_support.TESTFN, "wb")
  270. try:
  271. print >> fo, s,
  272. fo.close()
  273. fo = open(test_support.TESTFN, "rb")
  274. self.assertEqual(fo.read(), repr(s))
  275. finally:
  276. fo.close()
  277. test_support.unlink(test_support.TESTFN)
  278. def test_do_not_rehash_dict_keys(self):
  279. n = 10
  280. d = dict.fromkeys(map(HashCountingInt, xrange(n)))
  281. self.assertEqual(sum(elem.hash_count for elem in d), n)
  282. s = self.thetype(d)
  283. self.assertEqual(sum(elem.hash_count for elem in d), n)
  284. s.difference(d)
  285. self.assertEqual(sum(elem.hash_count for elem in d), n)
  286. if hasattr(s, 'symmetric_difference_update'):
  287. s.symmetric_difference_update(d)
  288. self.assertEqual(sum(elem.hash_count for elem in d), n)
  289. d2 = dict.fromkeys(set(d))
  290. self.assertEqual(sum(elem.hash_count for elem in d), n)
  291. d3 = dict.fromkeys(frozenset(d))
  292. self.assertEqual(sum(elem.hash_count for elem in d), n)
  293. d3 = dict.fromkeys(frozenset(d), 123)
  294. self.assertEqual(sum(elem.hash_count for elem in d), n)
  295. self.assertEqual(d3, dict.fromkeys(d, 123))
  296. def test_container_iterator(self):
  297. # Bug #3680: tp_traverse was not implemented for set iterator object
  298. class C(object):
  299. pass
  300. obj = C()
  301. ref = weakref.ref(obj)
  302. container = set([obj, 1])
  303. obj.x = iter(container)
  304. del obj, container
  305. gc.collect()
  306. self.assert_(ref() is None, "Cycle was not collected")
  307. class TestSet(TestJointOps):
  308. thetype = set
  309. def test_init(self):
  310. s = self.thetype()
  311. s.__init__(self.word)
  312. self.assertEqual(s, set(self.word))
  313. s.__init__(self.otherword)
  314. self.assertEqual(s, set(self.otherword))
  315. self.assertRaises(TypeError, s.__init__, s, 2);
  316. self.assertRaises(TypeError, s.__init__, 1);
  317. def test_constructor_identity(self):
  318. s = self.thetype(range(3))
  319. t = self.thetype(s)
  320. self.assertNotEqual(id(s), id(t))
  321. def test_hash(self):
  322. self.assertRaises(TypeError, hash, self.s)
  323. def test_clear(self):
  324. self.s.clear()
  325. self.assertEqual(self.s, set())
  326. self.assertEqual(len(self.s), 0)
  327. def test_copy(self):
  328. dup = self.s.copy()
  329. self.assertEqual(self.s, dup)
  330. self.assertNotEqual(id(self.s), id(dup))
  331. def test_add(self):
  332. self.s.add('Q')
  333. self.assert_('Q' in self.s)
  334. dup = self.s.copy()
  335. self.s.add('Q')
  336. self.assertEqual(self.s, dup)
  337. self.assertRaises(TypeError, self.s.add, [])
  338. def test_remove(self):
  339. self.s.remove('a')
  340. self.assert_('a' not in self.s)
  341. self.assertRaises(KeyError, self.s.remove, 'Q')
  342. self.assertRaises(TypeError, self.s.remove, [])
  343. s = self.thetype([frozenset(self.word)])
  344. self.assert_(self.thetype(self.word) in s)
  345. s.remove(self.thetype(self.word))
  346. self.assert_(self.thetype(self.word) not in s)
  347. self.assertRaises(KeyError, self.s.remove, self.thetype(self.word))
  348. def test_remove_keyerror_unpacking(self):
  349. # bug: www.python.org/sf/1576657
  350. for v1 in ['Q', (1,)]:
  351. try:
  352. self.s.remove(v1)
  353. except KeyError, e:
  354. v2 = e.args[0]
  355. self.assertEqual(v1, v2)
  356. else:
  357. self.fail()
  358. def test_remove_keyerror_set(self):
  359. key = self.thetype([3, 4])
  360. try:
  361. self.s.remove(key)
  362. except KeyError as e:
  363. self.assert_(e.args[0] is key,
  364. "KeyError should be {0}, not {1}".format(key,
  365. e.args[0]))
  366. else:
  367. self.fail()
  368. def test_discard(self):
  369. self.s.discard('a')
  370. self.assert_('a' not in self.s)
  371. self.s.discard('Q')
  372. self.assertRaises(TypeError, self.s.discard, [])
  373. s = self.thetype([frozenset(self.word)])
  374. self.assert_(self.thetype(self.word) in s)
  375. s.discard(self.thetype(self.word))
  376. self.assert_(self.thetype(self.word) not in s)
  377. s.discard(self.thetype(self.word))
  378. def test_pop(self):
  379. for i in xrange(len(self.s)):
  380. elem = self.s.pop()
  381. self.assert_(elem not in self.s)
  382. self.assertRaises(KeyError, self.s.pop)
  383. def test_update(self):
  384. retval = self.s.update(self.otherword)
  385. self.assertEqual(retval, None)
  386. for c in (self.word + self.otherword):
  387. self.assert_(c in self.s)
  388. self.assertRaises(PassThru, self.s.update, check_pass_thru())
  389. self.assertRaises(TypeError, self.s.update, [[]])
  390. for p, q in (('cdc', 'abcd'), ('efgfe', 'abcefg'), ('ccb', 'abc'), ('ef', 'abcef')):
  391. for C in set, frozenset, dict.fromkeys, str, unicode, list, tuple:
  392. s = self.thetype('abcba')
  393. self.assertEqual(s.update(C(p)), None)
  394. self.assertEqual(s, set(q))
  395. for p in ('cdc', 'efgfe', 'ccb', 'ef', 'abcda'):
  396. q = 'ahi'
  397. for C in set, frozenset, dict.fromkeys, str, unicode, list, tuple:
  398. s = self.thetype('abcba')
  399. self.assertEqual(s.update(C(p), C(q)), None)
  400. self.assertEqual(s, set(s) | set(p) | set(q))
  401. def test_ior(self):
  402. self.s |= set(self.otherword)
  403. for c in (self.word + self.otherword):
  404. self.assert_(c in self.s)
  405. def test_intersection_update(self):
  406. retval = self.s.intersection_update(self.otherword)
  407. self.assertEqual(retval, None)
  408. for c in (self.word + self.otherword):
  409. if c in self.otherword and c in self.word:
  410. self.assert_(c in self.s)
  411. else:
  412. self.assert_(c not in self.s)
  413. self.assertRaises(PassThru, self.s.intersection_update, check_pass_thru())
  414. self.assertRaises(TypeError, self.s.intersection_update, [[]])
  415. for p, q in (('cdc', 'c'), ('efgfe', ''), ('ccb', 'bc'), ('ef', '')):
  416. for C in set, frozenset, dict.fromkeys, str, unicode, list, tuple:
  417. s = self.thetype('abcba')
  418. self.assertEqual(s.intersection_update(C(p)), None)
  419. self.assertEqual(s, set(q))
  420. ss = 'abcba'
  421. s = self.thetype(ss)
  422. t = 'cbc'
  423. self.assertEqual(s.intersection_update(C(p), C(t)), None)
  424. self.assertEqual(s, set('abcba')&set(p)&set(t))
  425. def test_iand(self):
  426. self.s &= set(self.otherword)
  427. for c in (self.word + self.otherword):
  428. if c in self.otherword and c in self.word:
  429. self.assert_(c in self.s)
  430. else:
  431. self.assert_(c not in self.s)
  432. def test_difference_update(self):
  433. retval = self.s.difference_update(self.otherword)
  434. self.assertEqual(retval, None)
  435. for c in (self.word + self.otherword):
  436. if c in self.word and c not in self.otherword:
  437. self.assert_(c in self.s)
  438. else:
  439. self.assert_(c not in self.s)
  440. self.assertRaises(PassThru, self.s.difference_update, check_pass_thru())
  441. self.assertRaises(TypeError, self.s.difference_update, [[]])
  442. self.assertRaises(TypeError, self.s.symmetric_difference_update, [[]])
  443. for p, q in (('cdc', 'ab'), ('efgfe', 'abc'), ('ccb', 'a'), ('ef', 'abc')):
  444. for C in set, frozenset, dict.fromkeys, str, unicode, list, tuple:
  445. s = self.thetype('abcba')
  446. self.assertEqual(s.difference_update(C(p)), None)
  447. self.assertEqual(s, set(q))
  448. s = self.thetype('abcdefghih')
  449. s.difference_update()
  450. self.assertEqual(s, self.thetype('abcdefghih'))
  451. s = self.thetype('abcdefghih')
  452. s.difference_update(C('aba'))
  453. self.assertEqual(s, self.thetype('cdefghih'))
  454. s = self.thetype('abcdefghih')
  455. s.difference_update(C('cdc'), C('aba'))
  456. self.assertEqual(s, self.thetype('efghih'))
  457. def test_isub(self):
  458. self.s -= set(self.otherword)
  459. for c in (self.word + self.otherword):
  460. if c in self.word and c not in self.otherword:
  461. self.assert_(c in self.s)
  462. else:
  463. self.assert_(c not in self.s)
  464. def test_symmetric_difference_update(self):
  465. retval = self.s.symmetric_difference_update(self.otherword)
  466. self.assertEqual(retval, None)
  467. for c in (self.word + self.otherword):
  468. if (c in self.word) ^ (c in self.otherword):
  469. self.assert_(c in self.s)
  470. else:
  471. self.assert_(c not in self.s)
  472. self.assertRaises(PassThru, self.s.symmetric_difference_update, check_pass_thru())
  473. self.assertRaises(TypeError, self.s.symmetric_difference_update, [[]])
  474. for p, q in (('cdc', 'abd'), ('efgfe', 'abcefg'), ('ccb', 'a'), ('ef', 'abcef')):
  475. for C in set, frozenset, dict.fromkeys, str, unicode, list, tuple:
  476. s = self.thetype('abcba')
  477. self.assertEqual(s.symmetric_difference_update(C(p)), None)
  478. self.assertEqual(s, set(q))
  479. def test_ixor(self):
  480. self.s ^= set(self.otherword)
  481. for c in (self.word + self.otherword):
  482. if (c in self.word) ^ (c in self.otherword):
  483. self.assert_(c in self.s)
  484. else:
  485. self.assert_(c not in self.s)
  486. def test_inplace_on_self(self):
  487. t = self.s.copy()
  488. t |= t
  489. self.assertEqual(t, self.s)
  490. t &= t
  491. self.assertEqual(t, self.s)
  492. t -= t
  493. self.assertEqual(t, self.thetype())
  494. t = self.s.copy()
  495. t ^= t
  496. self.assertEqual(t, self.thetype())
  497. def test_weakref(self):
  498. s = self.thetype('gallahad')
  499. p = weakref.proxy(s)
  500. self.assertEqual(str(p), str(s))
  501. s = None
  502. self.assertRaises(ReferenceError, str, p)
  503. # C API test only available in a debug build
  504. if hasattr(set, "test_c_api"):
  505. def test_c_api(self):
  506. self.assertEqual(set('abc').test_c_api(), True)
  507. class SetSubclass(set):
  508. pass
  509. class TestSetSubclass(TestSet):
  510. thetype = SetSubclass
  511. class SetSubclassWithKeywordArgs(set):
  512. def __init__(self, iterable=[], newarg=None):
  513. set.__init__(self, iterable)
  514. class TestSetSubclassWithKeywordArgs(TestSet):
  515. def test_keywords_in_subclass(self):
  516. 'SF bug #1486663 -- this used to erroneously raise a TypeError'
  517. SetSubclassWithKeywordArgs(newarg=1)
  518. class TestFrozenSet(TestJointOps):
  519. thetype = frozenset
  520. def test_init(self):
  521. s = self.thetype(self.word)
  522. s.__init__(self.otherword)
  523. self.assertEqual(s, set(self.word))
  524. def test_singleton_empty_frozenset(self):
  525. f = frozenset()
  526. efs = [frozenset(), frozenset([]), frozenset(()), frozenset(''),
  527. frozenset(), frozenset([]), frozenset(()), frozenset(''),
  528. frozenset(xrange(0)), frozenset(frozenset()),
  529. frozenset(f), f]
  530. # All of the empty frozensets should have just one id()
  531. self.assertEqual(len(set(map(id, efs))), 1)
  532. def test_constructor_identity(self):
  533. s = self.thetype(range(3))
  534. t = self.thetype(s)
  535. self.assertEqual(id(s), id(t))
  536. def test_hash(self):
  537. self.assertEqual(hash(self.thetype('abcdeb')),
  538. hash(self.thetype('ebecda')))
  539. # make sure that all permutations give the same hash value
  540. n = 100
  541. seq = [randrange(n) for i in xrange(n)]
  542. results = set()
  543. for i in xrange(200):
  544. shuffle(seq)
  545. results.add(hash(self.thetype(seq)))
  546. self.assertEqual(len(results), 1)
  547. def test_copy(self):
  548. dup = self.s.copy()
  549. self.assertEqual(id(self.s), id(dup))
  550. def test_frozen_as_dictkey(self):
  551. seq = range(10) + list('abcdefg') + ['apple']
  552. key1 = self.thetype(seq)
  553. key2 = self.thetype(reversed(seq))
  554. self.assertEqual(key1, key2)
  555. self.assertNotEqual(id(key1), id(key2))
  556. d = {}
  557. d[key1] = 42
  558. self.assertEqual(d[key2], 42)
  559. def test_hash_caching(self):
  560. f = self.thetype('abcdcda')
  561. self.assertEqual(hash(f), hash(f))
  562. def test_hash_effectiveness(self):
  563. n = 13
  564. hashvalues = set()
  565. addhashvalue = hashvalues.add
  566. elemmasks = [(i+1, 1<<i) for i in range(n)]
  567. for i in xrange(2**n):
  568. addhashvalue(hash(frozenset([e for e, m in elemmasks if m&i])))
  569. self.assertEqual(len(hashvalues), 2**n)
  570. class FrozenSetSubclass(frozenset):
  571. pass
  572. class TestFrozenSetSubclass(TestFrozenSet):
  573. thetype = FrozenSetSubclass
  574. def test_constructor_identity(self):
  575. s = self.thetype(range(3))
  576. t = self.thetype(s)
  577. self.assertNotEqual(id(s), id(t))
  578. def test_copy(self):
  579. dup = self.s.copy()
  580. self.assertNotEqual(id(self.s), id(dup))
  581. def test_nested_empty_constructor(self):
  582. s = self.thetype()
  583. t = self.thetype(s)
  584. self.assertEqual(s, t)
  585. def test_singleton_empty_frozenset(self):
  586. Frozenset = self.thetype
  587. f = frozenset()
  588. F = Frozenset()
  589. efs = [Frozenset(), Frozenset([]), Frozenset(()), Frozenset(''),
  590. Frozenset(), Frozenset([]), Frozenset(()), Frozenset(''),
  591. Frozenset(xrange(0)), Frozenset(Frozenset()),
  592. Frozenset(frozenset()), f, F, Frozenset(f), Frozenset(F)]
  593. # All empty frozenset subclass instances should have different ids
  594. self.assertEqual(len(set(map(id, efs))), len(efs))
  595. # Tests taken from test_sets.py =============================================
  596. empty_set = set()
  597. #==============================================================================
  598. class TestBasicOps(unittest.TestCase):
  599. def test_repr(self):
  600. if self.repr is not None:
  601. self.assertEqual(repr(self.set), self.repr)
  602. def test_print(self):
  603. fo = open(test_support.TESTFN, "wb")
  604. try:
  605. print >> fo, self.set,
  606. fo.close()
  607. fo = open(test_support.TESTFN, "rb")
  608. self.assertEqual(fo.read(), repr(self.set))
  609. finally:
  610. fo.close()
  611. test_support.unlink(test_support.TESTFN)
  612. def test_length(self):
  613. self.assertEqual(len(self.set), self.length)
  614. def test_self_equality(self):
  615. self.assertEqual(self.set, self.set)
  616. def test_equivalent_equality(self):
  617. self.assertEqual(self.set, self.dup)
  618. def test_copy(self):
  619. self.assertEqual(self.set.copy(), self.dup)
  620. def test_self_union(self):
  621. result = self.set | self.set
  622. self.assertEqual(result, self.dup)
  623. def test_empty_union(self):
  624. result = self.set | empty_set
  625. self.assertEqual(result, self.dup)
  626. def test_union_empty(self):
  627. result = empty_set | self.set
  628. self.assertEqual(result, self.dup)
  629. def test_self_intersection(self):
  630. result = self.set & self.set
  631. self.assertEqual(result, self.dup)
  632. def test_empty_intersection(self):
  633. result = self.set & empty_set
  634. self.assertEqual(result, empty_set)
  635. def test_intersection_empty(self):
  636. result = empty_set & self.set
  637. self.assertEqual(result, empty_set)
  638. def test_self_isdisjoint(self):
  639. result = self.set.isdisjoint(self.set)
  640. self.assertEqual(result, not self.set)
  641. def test_empty_isdisjoint(self):
  642. result = self.set.isdisjoint(empty_set)
  643. self.assertEqual(result, True)
  644. def test_isdisjoint_empty(self):
  645. result = empty_set.isdisjoint(self.set)
  646. self.assertEqual(result, True)
  647. def test_self_symmetric_difference(self):
  648. result = self.set ^ self.set
  649. self.assertEqual(result, empty_set)
  650. def checkempty_symmetric_difference(self):
  651. result = self.set ^ empty_set
  652. self.assertEqual(result, self.set)
  653. def test_self_difference(self):
  654. result = self.set - self.set
  655. self.assertEqual(result, empty_set)
  656. def test_empty_difference(self):
  657. result = self.set - empty_set
  658. self.assertEqual(result, self.dup)
  659. def test_empty_difference_rev(self):
  660. result = empty_set - self.set
  661. self.assertEqual(result, empty_set)
  662. def test_iteration(self):
  663. for v in self.set:
  664. self.assert_(v in self.values)
  665. setiter = iter(self.set)
  666. # note: __length_hint__ is an internal undocumented API,
  667. # don't rely on it in your own programs
  668. self.assertEqual(setiter.__length_hint__(), len(self.set))
  669. def test_pickling(self):
  670. p = pickle.dumps(self.set)
  671. copy = pickle.loads(p)
  672. self.assertEqual(self.set, copy,
  673. "%s != %s" % (self.set, copy))
  674. #------------------------------------------------------------------------------
  675. class TestBasicOpsEmpty(TestBasicOps):
  676. def setUp(self):
  677. self.case = "empty set"
  678. self.values = []
  679. self.set = set(self.values)
  680. self.dup = set(self.values)
  681. self.length = 0
  682. self.repr = "set([])"
  683. #------------------------------------------------------------------------------
  684. class TestBasicOpsSingleton(TestBasicOps):
  685. def setUp(self):
  686. self.case = "unit set (number)"
  687. self.values = [3]
  688. self.set = set(self.values)
  689. self.dup = set(self.values)
  690. self.length = 1
  691. self.repr = "set([3])"
  692. def test_in(self):
  693. self.failUnless(3 in self.set)
  694. def test_not_in(self):
  695. self.failUnless(2 not in self.set)
  696. #------------------------------------------------------------------------------
  697. class TestBasicOpsTuple(TestBasicOps):
  698. def setUp(self):
  699. self.case = "unit set (tuple)"
  700. self.values = [(0, "zero")]
  701. self.set = set(self.values)
  702. self.dup = set(self.values)
  703. self.length = 1
  704. self.repr = "set([(0, 'zero')])"
  705. def test_in(self):
  706. self.failUnless((0, "zero") in self.set)
  707. def test_not_in(self):
  708. self.failUnless(9 not in self.set)
  709. #------------------------------------------------------------------------------
  710. class TestBasicOpsTriple(TestBasicOps):
  711. def setUp(self):
  712. self.case = "triple set"
  713. self.values = [0, "zero", operator.add]
  714. self.set = set(self.values)
  715. self.dup = set(self.values)
  716. self.length = 3
  717. self.repr = None
  718. #==============================================================================
  719. def baditer():
  720. raise TypeError
  721. yield True
  722. def gooditer():
  723. yield True
  724. class TestExceptionPropagation(unittest.TestCase):
  725. """SF 628246: Set constructor should not trap iterator TypeErrors"""
  726. def test_instanceWithException(self):
  727. self.assertRaises(TypeError, set, baditer())
  728. def test_instancesWithoutException(self):
  729. # All of these iterables should load without exception.
  730. set([1,2,3])
  731. set((1,2,3))
  732. set({'one':1, 'two':2, 'three':3})
  733. set(xrange(3))
  734. set('abc')
  735. set(gooditer())
  736. def test_changingSizeWhileIterating(self):
  737. s = set([1,2,3])
  738. try:
  739. for i in s:
  740. s.update([4])
  741. except RuntimeError:
  742. pass
  743. else:
  744. self.fail("no exception when changing size during iteration")
  745. #==============================================================================
  746. class TestSetOfSets(unittest.TestCase):
  747. def test_constructor(self):
  748. inner = frozenset([1])
  749. outer = set([inner])
  750. element = outer.pop()
  751. self.assertEqual(type(element), frozenset)
  752. outer.add(inner) # Rebuild set of sets with .add method
  753. outer.remove(inner)
  754. self.assertEqual(outer, set()) # Verify that remove worked
  755. outer.discard(inner) # Absence of KeyError indicates working fine
  756. #==============================================================================
  757. class TestBinaryOps(unittest.TestCase):
  758. def setUp(self):
  759. self.set = set((2, 4, 6))
  760. def test_eq(self): # SF bug 643115
  761. self.assertEqual(self.set, set({2:1,4:3,6:5}))
  762. def test_union_subset(self):
  763. result = self.set | set([2])
  764. self.assertEqual(result, set((2, 4, 6)))
  765. def test_union_superset(self):
  766. result = self.set | set([2, 4, 6, 8])
  767. self.assertEqual(result, set([2, 4, 6, 8]))
  768. def test_union_overlap(self):
  769. result = self.set | set([3, 4, 5])
  770. self.assertEqual(result, set([2, 3, 4, 5, 6]))
  771. def test_union_non_overlap(self):
  772. result = self.set | set([8])
  773. self.assertEqual(result, set([2, 4, 6, 8]))
  774. def test_intersection_subset(self):
  775. result = self.set & set((2, 4))
  776. self.assertEqual(result, set((2, 4)))
  777. def test_intersection_superset(self):
  778. result = self.set & set([2, 4, 6, 8])
  779. self.assertEqual(result, set([2, 4, 6]))
  780. def test_intersection_overlap(self):
  781. result = self.set & set([3, 4, 5])
  782. self.assertEqual(result, set([4]))
  783. def test_intersection_non_overlap(self):
  784. result = self.set & set([8])
  785. self.assertEqual(result, empty_set)
  786. def test_isdisjoint_subset(self):
  787. result = self.set.isdisjoint(set((2, 4)))
  788. self.assertEqual(result, False)
  789. def test_isdisjoint_superset(self):
  790. result = self.set.isdisjoint(set([2, 4, 6, 8]))
  791. self.assertEqual(result, False)
  792. def test_isdisjoint_overlap(self):
  793. result = self.set.isdisjoint(set([3, 4, 5]))
  794. self.assertEqual(result, False)
  795. def test_isdisjoint_non_overlap(self):
  796. result = self.set.isdisjoint(set([8]))
  797. self.assertEqual(result, True)
  798. def test_sym_difference_subset(self):
  799. result = self.set ^ set((2, 4))
  800. self.assertEqual(result, set([6]))
  801. def test_sym_difference_superset(self):
  802. result = self.set ^ set((2, 4, 6, 8))
  803. self.assertEqual(result, set([8]))
  804. def test_sym_difference_overlap(self):
  805. result = self.set ^ set((3, 4, 5))
  806. self.assertEqual(result, set([2, 3, 5, 6]))
  807. def test_sym_difference_non_overlap(self):
  808. result = self.set ^ set([8])
  809. self.assertEqual(result, set([2, 4, 6, 8]))
  810. def test_cmp(self):
  811. a, b = set('a'), set('b')
  812. self.assertRaises(TypeError, cmp, a, b)
  813. # You can view this as a buglet: cmp(a, a) does not raise TypeError,
  814. # because __eq__ is tried before __cmp__, and a.__eq__(a) returns True,
  815. # which Python thinks is good enough to synthesize a cmp() result
  816. # without calling __cmp__.
  817. self.assertEqual(cmp(a, a), 0)
  818. self.assertRaises(TypeError, cmp, a, 12)
  819. self.assertRaises(TypeError, cmp, "abc", a)
  820. #==============================================================================
  821. class TestUpdateOps(unittest.TestCase):
  822. def setUp(self):
  823. self.set = set((2, 4, 6))
  824. def test_union_subset(self):
  825. self.set |= set([2])
  826. self.assertEqual(self.set, set((2, 4, 6)))
  827. def test_union_superset(self):
  828. self.set |= set([2, 4, 6, 8])
  829. self.assertEqual(self.set, set([2, 4, 6, 8]))
  830. def test_union_overlap(self):
  831. self.set |= set([3, 4, 5])
  832. self.assertEqual(self.set, set([2, 3, 4, 5, 6]))
  833. def test_union_non_overlap(self):
  834. self.set |= set([8])
  835. self.assertEqual(self.set, set([2, 4, 6, 8]))
  836. def test_union_method_call(self):
  837. self.set.update(set([3, 4, 5]))
  838. self.assertEqual(self.set, set([2, 3, 4, 5, 6]))
  839. def test_intersection_subset(self):
  840. self.set &= set((2, 4))
  841. self.assertEqual(self.set, set((2, 4)))
  842. def test_intersection_superset(self):
  843. self.set &= set([2, 4, 6, 8])
  844. self.assertEqual(self.set, set([2, 4, 6]))
  845. def test_intersection_overlap(self):
  846. self.set &= set([3, 4, 5])
  847. self.assertEqual(self.set, set([4]))
  848. def test_intersection_non_overlap(self):
  849. self.set &= set([8])
  850. self.assertEqual(self.set, empty_set)
  851. def test_intersection_method_call(self):
  852. self.set.intersection_update(set([3, 4, 5]))
  853. self.assertEqual(self.set, set([4]))
  854. def test_sym_difference_subset(self):
  855. self.set ^= set((2, 4))
  856. self.assertEqual(self.set, set([6]))
  857. def test_sym_difference_superset(self):
  858. self.set ^= set((2, 4, 6, 8))
  859. self.assertEqual(self.set, set([8]))
  860. def test_sym_difference_overlap(self):
  861. self.set ^= set((3, 4, 5))
  862. self.assertEqual(self.set, set([2, 3, 5, 6]))
  863. def test_sym_difference_non_overlap(self):
  864. self.set ^= set([8])
  865. self.assertEqual(self.set, set([2, 4, 6, 8]))
  866. def test_sym_difference_method_call(self):
  867. self.set.symmetric_difference_update(set([3, 4, 5]))
  868. self.assertEqual(self.set, set([2, 3, 5, 6]))
  869. def test_difference_subset(self):
  870. self.set -= set((2, 4))
  871. self.assertEqual(self.set, set([6]))
  872. def test_difference_superset(self):
  873. self.set -= set((2, 4, 6, 8))
  874. self.assertEqual(self.set, set([]))
  875. def test_difference_overlap(self):
  876. self.set -= set((3, 4, 5))
  877. self.assertEqual(self.set, set([2, 6]))
  878. def test_difference_non_overlap(self):
  879. self.set -= set([8])
  880. self.assertEqual(self.set, set([2, 4, 6]))
  881. def test_difference_method_call(self):
  882. self.set.difference_update(set([3, 4, 5]))
  883. self.assertEqual(self.set, set([2, 6]))
  884. #==============================================================================
  885. class TestMutate(unittest.TestCase):
  886. def setUp(self):
  887. self.values = ["a", "b", "c"]
  888. self.set = set(self.values)
  889. def test_add_present(self):
  890. self.set.add("c")
  891. self.assertEqual(self.set, set("abc"))
  892. def test_add_absent(self):
  893. self.set.add("d")
  894. self.assertEqual(self.set, set("abcd"))
  895. def test_add_until_full(self):
  896. tmp = set()
  897. expected_len = 0
  898. for v in self.values:
  899. tmp.add(v)
  900. expected_len += 1
  901. self.assertEqual(len(tmp), expected_len)
  902. self.assertEqual(tmp, self.set)
  903. def test_remove_present(self):
  904. self.set.remove("b")
  905. self.assertEqual(self.set, set("ac"))
  906. def test_remove_absent(self):
  907. try:
  908. self.set.remove("d")
  909. self.fail("Removing missing element should have raised LookupError")
  910. except LookupError:
  911. pass
  912. def test_remove_until_empty(self):
  913. expected_len = len(self.set)
  914. for v in self.values:
  915. self.set.remove(v)
  916. expected_len -= 1
  917. self.assertEqual(len(self.set), expected_len)
  918. def test_discard_present(self):
  919. self.set.discard("c")
  920. self.assertEqual(self.set, set("ab"))
  921. def test_discard_absent(self):
  922. self.set.discard("d")
  923. self.assertEqual(self.set, set("abc"))
  924. def test_clear(self):
  925. self.set.clear()
  926. self.assertEqual(len(self.set), 0)
  927. def test_pop(self):
  928. popped = {}
  929. while self.set:
  930. popped[self.set.pop()] = None
  931. self.assertEqual(len(popped), len(self.values))
  932. for v in self.values:
  933. self.failUnless(v in popped)
  934. def test_update_empty_tuple(self):
  935. self.set.update(())
  936. self.assertEqual(self.set, set(self.values))
  937. def test_update_unit_tuple_overlap(self):
  938. self.set.update(("a",))
  939. self.assertEqual(self.set, set(self.values))
  940. def test_update_unit_tuple_non_overlap(self):
  941. self.set.update(("a", "z"))
  942. self.assertEqual(self.set, set(self.values + ["z"]))
  943. #==============================================================================
  944. class TestSubsets(unittest.TestCase):
  945. case2method = {"<=": "issubset",
  946. ">=": "issuperset",
  947. }
  948. reverse = {"==": "==",
  949. "!=": "!=",
  950. "<": ">",
  951. ">": "<",
  952. "<=": ">=",
  953. ">=": "<=",
  954. }
  955. def test_issubset(self):
  956. x = self.left
  957. y = self.right
  958. for case in "!=", "==", "<", "<=", ">", ">=":
  959. expected = case in self.cases
  960. # Test the binary infix spelling.
  961. result = eval("x" + case + "y", locals())
  962. self.assertEqual(result, expected)
  963. # Test the "friendly" method-name spelling, if one exists.
  964. if case in TestSubsets.case2method:
  965. method = getattr(x, TestSubsets.case2method[case])
  966. result = method(y)
  967. self.assertEqual(result, expected)
  968. # Now do the same for the operands reversed.
  969. rcase = TestSubsets.reverse[case]
  970. result = eval("y" + rcase + "x", locals())
  971. self.assertEqual(result, expected)
  972. if rcase in TestSubsets.case2method:
  973. method = getattr(y, TestSubsets.case2method[rcase])
  974. result = method(x)
  975. self.assertEqual(result, expected)
  976. #------------------------------------------------------------------------------
  977. class TestSubsetEqualEmpty(TestSubsets):
  978. left = set()
  979. right = set()
  980. name = "both empty"
  981. cases = "==", "<=", ">="
  982. #------------------------------------------------------------------------------
  983. class TestSubsetEqualNonEmpty(TestSubsets):
  984. left = set([1, 2])
  985. right = set([1, 2])
  986. name = "equal pair"
  987. cases = "==", "<=", ">="
  988. #------------------------------------------------------------------------------
  989. class TestSubsetEmptyNonEmpty(TestSubsets):
  990. left = set()
  991. right = set([1, 2])
  992. name = "one empty, one non-empty"
  993. cases = "!=", "<", "<="
  994. #------------------------------------------------------------------------------
  995. class TestSubsetPartial(TestSubsets):
  996. left = set([1])
  997. right = set([1, 2])
  998. name = "one a non-empty proper subset of other"
  999. cases = "!=", "<", "<="
  1000. #------------------------------------------------------------------------------
  1001. class TestSubsetNonOverlap(TestSubsets):
  1002. left = set([1])
  1003. right = set([2])
  1004. name = "neither empty, neither contains"
  1005. cases = "!="
  1006. #==============================================================================
  1007. class TestOnlySetsInBinaryOps(unittest.TestCase):
  1008. def test_eq_ne(self):
  1009. # Unlike the others, this is testing that == and != *are* allowed.
  1010. self.assertEqual(self.other == self.set, False)
  1011. self.assertEqual(self.set == self.other, False)
  1012. self.assertEqual(self.other != self.set, True)
  1013. self.assertEqual(self.set != self.other, True)
  1014. def test_ge_gt_le_lt(self):
  1015. self.assertRaises(TypeError, lambda: self.set < self.other)
  1016. self.assertRaises(TypeError, lambda: self.set <= self.other)
  1017. self.assertRaises(TypeError, lambda: self.set > self.other)
  1018. self.assertRaises(TypeError, lambda: self.set >= self.other)
  1019. self.assertRaises(TypeError, lambda: self.other < self.set)
  1020. self.assertRaises(TypeError, lambda: self.other <= self.set)
  1021. self.assertRaises(TypeError, lambda: self.other > self.set)
  1022. self.assertRaises(TypeError, lambda: self.other >= self.set)
  1023. def test_update_operator(self):
  1024. try:
  1025. self.set |= self.other
  1026. except TypeError:
  1027. pass
  1028. else:
  1029. self.fail("expected TypeError")
  1030. def test_update(self):
  1031. if self.otherIsIterable:
  1032. self.set.update(self.other)
  1033. else:
  1034. self.assertRaises(TypeError, self.set.update, self.other)
  1035. def test_union(self):
  1036. self.assertRaises(TypeError, lambda: self.set | self.other)
  1037. self.assertRaises(TypeError, lambda: self.other | self.set)
  1038. if self.otherIsIterable:
  1039. self.set.union(self.other)
  1040. else:
  1041. self.assertRaises(TypeError, self.set.union, self.other)
  1042. def test_intersection_update_operator(self):
  1043. try:
  1044. self.set &= self.other
  1045. except TypeError:
  1046. pass
  1047. else:
  1048. self.fail("expected TypeError")
  1049. def test_intersection_update(self):
  1050. if self.otherIsIterable:
  1051. self.set.intersection_update(self.other)
  1052. else:
  1053. self.assertRaises(TypeError,
  1054. self.set.intersection_update,
  1055. self.other)
  1056. def test_intersection(self):
  1057. self.assertRaises(TypeError, lambda: self.set & self.other)
  1058. self.assertRaises(TypeError, lambda: self.other & self.set)
  1059. if self.otherIsIterable:
  1060. self.set.intersection(self.other)
  1061. else:
  1062. self.assertRaises(TypeError, self.set.intersection, self.other)
  1063. def test_sym_difference_update_operator(self):
  1064. try:
  1065. self.set ^= self.other
  1066. except TypeError:
  1067. pass
  1068. else:
  1069. self.fail("expected TypeError")
  1070. def test_sym_difference_update(self):
  1071. if self.otherIsIterable:
  1072. self.set.symmetric_difference_update(self.other)
  1073. else:
  1074. self.assertRaises(TypeError,
  1075. self.set.symmetric_difference_update,
  1076. self.other)
  1077. def test_sym_difference(self):
  1078. self.assertRaises(TypeError, lambda: self.set ^ self.other)
  1079. self.assertRaises(TypeError, lambda: self.other ^ self.set)
  1080. if self.otherIsIterable:
  1081. self.set.symmetric_difference(self.other)
  1082. else:
  1083. self.assertRaises(TypeError, self.set.symmetric_difference, self.other)
  1084. def test_difference_update_operator(self):
  1085. try:
  1086. self.set -= self.other
  1087. except TypeError:
  1088. pass
  1089. else:
  1090. self.fail("expected TypeError")
  1091. def test_difference_update(self):
  1092. if self.otherIsIterable:
  1093. self.set.difference_update(self.other)
  1094. else:
  1095. self.assertRaises(TypeError,
  1096. self.set.difference_update,
  1097. self.other)
  1098. def test_difference(self):
  1099. self.assertRaises(TypeError, lambda: self.set - self.other)
  1100. self.assertRaises(TypeError, lambda: self.other - self.set)
  1101. if self.otherIsIterable:
  1102. self.set.difference(self.other)
  1103. else:
  1104. self.assertRaises(TypeError, self.set.difference, self.other)
  1105. #------------------------------------------------------------------------------
  1106. class TestOnlySetsNumeric(TestOnlySetsInBinaryOps):
  1107. def setUp(self):
  1108. self.set = set((1, 2, 3))
  1109. self.other = 19
  1110. self.otherIsIterable = False
  1111. #------------------------------------------------------------------------------
  1112. class TestOnlySetsDict(TestOnlySetsInBinaryOps):
  1113. def setUp(self):
  1114. self.set = set((1, 2, 3))
  1115. self.other = {1:2, 3:4}
  1116. self.otherIsIterable = True
  1117. #------------------------------------------------------------------------------
  1118. class TestOnlySetsOperator(TestOnlySetsInBinaryOps):
  1119. def setUp(self):
  1120. self.set = set((1, 2, 3))
  1121. self.other = operator.add
  1122. self.otherIsIterable = False
  1123. #------------------------------------------------------------------------------
  1124. class TestOnlySetsTuple(TestOnlySetsInBinaryOps):
  1125. def setUp(self):
  1126. self.set = set((1, 2, 3))
  1127. self.other = (2, 4, 6)
  1128. self.otherIsIterable = True
  1129. #------------------------------------------------------------------------------
  1130. class TestOnlySetsString(TestOnlySetsInBinaryOps):
  1131. def setUp(self):
  1132. self.set = set((1, 2, 3))
  1133. self.other = 'abc'
  1134. self.otherIsIterable = True
  1135. #------------------------------------------------------------------------------
  1136. class TestOnlySetsGenerator(TestOnlySetsInBinaryOps):
  1137. def setUp(self):
  1138. def gen():
  1139. for i in xrange(0, 10, 2):
  1140. yield i
  1141. self.set = set((1, 2, 3))
  1142. self.other = gen()
  1143. self.otherIsIterable = True
  1144. #==============================================================================
  1145. class TestCopying(unittest.TestCase):
  1146. def test_copy(self):
  1147. dup = self.set.copy()
  1148. dup_list = list(dup); dup_list.sort()
  1149. set_list = list(self.set); set_list.sort()
  1150. self.assertEqual(len(dup_list), len(set_list))
  1151. for i in range(len(dup_list)):
  1152. self.failUnless(dup_list[i] is set_list[i])
  1153. def test_deep_copy(self):
  1154. dup = copy.deepcopy(self.set)
  1155. ##print type(dup), repr(dup)
  1156. dup_list = list(dup); dup_list.sort()
  1157. set_list = list(self.set); set_list.sort()
  1158. self.assertEqual(len(dup_list), len(set_list))
  1159. for i in range(len(dup_list)):
  1160. self.assertEqual(dup_list[i], set_list[i])
  1161. #------------------------------------------------------------------------------
  1162. class TestCopyingEmpty(TestCopying):
  1163. def setUp(self):
  1164. self.set = set()
  1165. #------------------------------------------------------------------------------
  1166. class TestCopyingSingleton(TestCopying):
  1167. def setUp(self):
  1168. self.set = set(["hello"])
  1169. #------------------------------------------------------------------------------
  1170. class TestCopyingTriple(TestCopying):
  1171. def setUp(self):
  1172. self.set = set(["zero", 0, None])
  1173. #------------------------------------------------------------------------------
  1174. class TestCopyingTuple(TestCopying):
  1175. def setUp(self):
  1176. self.set = set([(1, 2)])
  1177. #------------------------------------------------------------------------------
  1178. class TestCopyingNested(TestCopying):
  1179. def setUp(self):
  1180. self.set = set([((1, 2), (3, 4))])
  1181. #==============================================================================
  1182. class TestIdentities(unittest.TestCase):
  1183. def setUp(self):
  1184. self.a = set('abracadabra')
  1185. self.b = set('alacazam')
  1186. def test_binopsVsSubsets(self):
  1187. a, b = self.a, self.b
  1188. self.assert_(a - b < a)
  1189. self.assert_(b - a < b)
  1190. self.assert_(a & b < a)
  1191. self.assert_(a & b < b)
  1192. self.assert_(a | b > a)
  1193. self.assert_(a | b > b)
  1194. self.assert_(a ^ b < a | b)
  1195. def test_commutativity(self):
  1196. a, b = self.a, self.b
  1197. self.assertEqual(a&b, b&a)
  1198. self.assertEqual(a|b, b|a)
  1199. self.assertEqual(a^b, b^a)
  1200. if a != b:
  1201. self.assertNotEqual(a-b, b-a)
  1202. def test_summations(self):
  1203. # check that sums of parts equal the whole
  1204. a, b = self.a, self.b
  1205. self.assertEqual((a-b)|(a&b)|(b-a), a|b)
  1206. self.assertEqual((a&b)|(a^b), a|b)
  1207. self.assertEqual(a|(b-a), a|b)
  1208. self.assertEqual((a-b)|b, a|b)
  1209. self.assertEqual((a-b)|(a&b), a)
  1210. self.assertEqual((b-a)|(a&b), b)
  1211. self.assertEqual((a-b)|(b-a), a^b)
  1212. def test_exclusion(self):
  1213. # check that inverse operations show non-overlap
  1214. a, b, zero = self.a, self.b, set()
  1215. self.assertEqual((a-b)&b, zero)
  1216. self.assertEqual((b-a)&a, zero)
  1217. self.assertEqual((a&b)&(a^b), zero)
  1218. # Tests derived from test_itertools.py =======================================
  1219. def R(seqn):
  1220. 'Regular generator'
  1221. for i in seqn:
  1222. yield i
  1223. class G:
  1224. 'Sequence using __getitem__'
  1225. def __init__(self, seqn):
  1226. self.seqn = seqn
  1227. def __getitem__(self, i):
  1228. return self.seqn[i]
  1229. class I:
  1230. 'Sequence using iterator protocol'
  1231. def __init__(self, seqn):
  1232. self.seqn = seqn
  1233. self.i = 0
  1234. def __iter__(self):
  1235. return self
  1236. def next(self):
  1237. if self.i >= len(self.seqn): raise StopIteration
  1238. v = self.seqn[self.i]
  1239. self.i += 1
  1240. return v
  1241. class Ig:
  1242. 'Sequence using iterator protocol defined with a generator'
  1243. def __init__(self, seqn):
  1244. self.seqn = seqn
  1245. self.i = 0
  1246. def __iter__(self):
  1247. for val in self.seqn:
  1248. yield val
  1249. class X:
  1250. 'Missing __getitem__ and __iter__'
  1251. def __init__(self, seqn):
  1252. self.seqn = seqn
  1253. self.i = 0
  1254. def next(self):
  1255. if self.i >= len(self.seqn): raise StopIteration
  1256. v = self.seqn[self.i]
  1257. self.i += 1
  1258. return v
  1259. class N:
  1260. 'Iterator missing next()'
  1261. def __init__(self, seqn):
  1262. self.seqn = seqn
  1263. self.i = 0
  1264. def __iter__(self):
  1265. return self
  1266. class E:
  1267. 'Test propagation of exceptions'
  1268. def __init__(self, seqn):
  1269. self.seqn = seqn
  1270. self.i = 0
  1271. def __iter__(self):
  1272. return self
  1273. def next(self):
  1274. 3 // 0
  1275. class S:
  1276. 'Test immediate stop'
  1277. def __init__(self, seqn):
  1278. pass
  1279. def __iter__(self):
  1280. return self
  1281. def next(self):
  1282. raise StopIteration
  1283. from itertools import chain, imap
  1284. def L(seqn):
  1285. 'Test multiple tiers of iterators'
  1286. return chain(imap(lambda x:x, R(Ig(G(seqn)))))
  1287. class TestVariousIteratorArgs(unittest.TestCase):
  1288. def test_constructor(self):
  1289. for cons in (set, frozenset):
  1290. for s in ("123", "", range(1000), ('do', 1.2), xrange(2000,2200,5)):
  1291. for g in (G, I, Ig, S, L, R):
  1292. self.assertEqual(sorted(cons(g(s))), sorted(g(s)))
  1293. self.assertRaises(TypeError, cons , X(s))
  1294. self.assertRaises(TypeError, cons , N(s))
  1295. self.assertRaises(ZeroDivisionError, cons , E(s))
  1296. def test_inline_methods(self):
  1297. s = set('november')
  1298. for data in ("123", "", range(1000), ('do', 1.2), xrange(2000,2200,5), 'december'):
  1299. for meth in (s.union, s.intersection, s.difference, s.symmetric_difference, s.isdisjoint):
  1300. for g in (G, I, Ig, L, R):
  1301. expected = meth(data)
  1302. actual = meth(G(data))
  1303. if isinstance(expected, bool):
  1304. self.assertEqual(actual, expected)
  1305. else:
  1306. self.assertEqual(sorted(actual), sorted(expected))
  1307. self.assertRaises(TypeError, meth, X(s))
  1308. self.assertRaises(TypeError, meth, N(s))
  1309. self.assertRaises(ZeroDivisionError, meth, E(s))
  1310. def test_inplace_methods(self):
  1311. for data in ("123", "", range(1000), ('do', 1.2), xrange(2000,2200,5), 'december'):
  1312. for methname in ('update', 'intersection_update',
  1313. 'difference_update', 'symmetric_difference_update'):
  1314. for g in (G, I, Ig, S, L, R):
  1315. s = set('january')
  1316. t = s.copy()
  1317. getattr(s, methname)(list(g(data)))
  1318. getattr(t, methname)(g(data))
  1319. self.assertEqual(sorted(s), sorted(t))
  1320. self.assertRaises(TypeError, getattr(set('january'), methname), X(data))
  1321. self.assertRaises(TypeError, getattr(set('january'), methname), N(data))
  1322. self.assertRaises(ZeroDivisionError, getattr(set('january'), methname), E(data))
  1323. # Application tests (based on David Eppstein's graph recipes ====================================
  1324. def powerset(U):
  1325. """Generates all subsets of a set or sequence U."""
  1326. U = iter(U)
  1327. try:
  1328. x = frozenset([U.next()])
  1329. for S in powerset(U):
  1330. yield S
  1331. yield S | x
  1332. except StopIteration:
  1333. yield frozenset()
  1334. def cube(n):
  1335. """Graph of n-dimensional hypercube."""
  1336. singletons = [frozenset([x]) for x in range(n)]
  1337. return dict([(x, frozenset([x^s for s in singletons]))
  1338. for x in powerset(range(n))])
  1339. def linegraph(G):
  1340. """Graph, the vertices of which are edges of G,
  1341. with two vertices being adjacent iff the corresponding
  1342. edges share a vertex."""
  1343. L = {}
  1344. for x in G:
  1345. for y in G[x]:
  1346. nx = [frozenset([x,z]) for z in G[x] if z != y]
  1347. ny = [frozenset([y,z]) for z in G[y] if z != x]
  1348. L[frozenset([x,y])] = frozenset(nx+ny)
  1349. return L
  1350. def faces(G):
  1351. 'Return a set of faces in G. Where a face is a set of vertices on that face'
  1352. # currently limited to triangles,squares, and pentagons
  1353. f = set()
  1354. for v1, edges in G.items():
  1355. for v2 in edges:
  1356. for v3 in G[v2]:
  1357. if v1 == v3:
  1358. continue
  1359. if v1 in G[v3]:
  1360. f.add(frozenset([v1, v2, v3]))
  1361. else:
  1362. for v4 in G[v3]:
  1363. if v4 == v2:
  1364. continue
  1365. if v1 in G[v4]:
  1366. f.add(frozenset([v1, v2, v3, v4]))
  1367. else:
  1368. for v5 in G[v4]:
  1369. if v5 == v3 or v5 == v2:
  1370. continue
  1371. if v1 in G[v5]:
  1372. f.add(frozenset([v1, v2, v3, v4, v5]))
  1373. return f
  1374. class TestGraphs(unittest.TestCase):
  1375. def test_cube(self):
  1376. g = cube(3) # vert --> {v1, v2, v3}
  1377. vertices1 = set(g)
  1378. self.assertEqual(len(vertices1), 8) # eight vertices
  1379. for edge in g.values():
  1380. self.assertEqual(len(edge), 3) # each vertex connects to three edges
  1381. vertices2 = set(v for edges in g.values() for v in edges)
  1382. self.assertEqual(vertices1, vertices2) # edge vertices in original set
  1383. cubefaces = faces(g)
  1384. self.assertEqual(len(cubefaces), 6) # six faces
  1385. for face in cubefaces:
  1386. self.assertEqual(len(face), 4) # each face is a square
  1387. def test_cuboctahedron(self):
  1388. # http://en.wikipedia.org/wiki/Cuboctahedron
  1389. # 8 triangular faces and 6 square faces
  1390. # 12 indentical vertices each connecting a triangle and square
  1391. g = cube(3)
  1392. cuboctahedron = linegraph(g) # V( --> {V1, V2, V3, V4}
  1393. self.assertEqual(len(cuboctahedron), 12)# twelve vertices
  1394. vertices = set(cuboctahedron)
  1395. for edges in cuboctahedron.values():
  1396. self.assertEqual(len(edges), 4) # each vertex connects to four other vertices
  1397. othervertices = set(edge for edges in cuboctahedron.values() for edge in edges)
  1398. self.assertEqual(vertices, othervertices) # edge vertices in original set
  1399. cubofaces = faces(cuboctahedron)
  1400. facesizes = collections.defaultdict(int)
  1401. for face in cubofaces:
  1402. facesizes[len(face)] += 1
  1403. self.assertEqual(facesizes[3], 8) # eight triangular faces
  1404. self.assertEqual(facesizes[4], 6) # six square faces
  1405. for vertex in cuboctahedron:
  1406. edge = vertex # Cuboctahedron vertices are edges in Cube
  1407. self.assertEqual(len(edge), 2) # Two cube vertices define an edge
  1408. for cubevert in edge:
  1409. self.assert_(cubevert in g)
  1410. #==============================================================================
  1411. def test_main(verbose=None):
  1412. from test import test_sets
  1413. test_classes = (
  1414. TestSet,
  1415. TestSetSubclass,
  1416. TestSetSubclassWithKeywordArgs,
  1417. TestFrozenSet,
  1418. TestFrozenSetSubclass,
  1419. TestSetOfSets,
  1420. TestExceptionPropagation,
  1421. TestBasicOpsEmpty,
  1422. TestBasicOpsSingleton,
  1423. TestBasicOpsTuple,
  1424. TestBasicOpsTriple,
  1425. TestBinaryOps,
  1426. TestUpdateOps,
  1427. TestMutate,
  1428. TestSubsetEqualEmpty,
  1429. TestSubsetEqualNonEmpty,
  1430. TestSubsetEmptyNonEmpty,
  1431. TestSubsetPartial,
  1432. TestSubsetNonOverlap,
  1433. TestOnlySetsNumeric,
  1434. TestOnlySetsDict,
  1435. TestOnlySetsOperator,
  1436. TestOnlySetsTuple,
  1437. TestOnlySetsString,
  1438. TestOnlySetsGenerator,
  1439. TestCopyingEmpty,
  1440. TestCopyingSingleton,
  1441. TestCopyingTriple,
  1442. TestCopyingTuple,
  1443. TestCopyingNested,
  1444. TestIdentities,
  1445. TestVariousIteratorArgs,
  1446. TestGraphs,
  1447. )
  1448. test_support.run_unittest(*test_classes)
  1449. # verify reference counting
  1450. if verbose and hasattr(sys, "gettotalrefcount"):
  1451. import gc
  1452. counts = [None] * 5
  1453. for i in xrange(len(counts)):
  1454. test_support.run_unittest(*test_classes)
  1455. gc.collect()
  1456. counts[i] = sys.gettotalrefcount()
  1457. print counts
  1458. if __name__ == "__main__":
  1459. test_main(verbose=True)