Fixes issue 1959. Converted tests to unittest.

Thanks Giampaolo Rodola.
This commit is contained in:
Facundo Batista 2008-02-06 19:28:49 +00:00
parent c16c57c733
commit 5af2f7454d

View file

@ -1,112 +1,84 @@
from test.test_support import TestFailed, have_unicode from test.test_support import have_unicode, run_unittest
import unittest
class base_set: class base_set:
def __init__(self, el): def __init__(self, el):
self.el = el self.el = el
class set(base_set): class set(base_set):
def __contains__(self, el): def __contains__(self, el):
return self.el == el return self.el == el
class seq(base_set): class seq(base_set):
def __getitem__(self, n): def __getitem__(self, n):
return [self.el][n] return [self.el][n]
def check(ok, *args):
if not ok:
raise TestFailed, " ".join(map(str, args))
a = base_set(1) class TestContains(unittest.TestCase):
b = set(1) def test_common_tests(self):
c = seq(1) a = base_set(1)
b = set(1)
c = seq(1)
self.assert_(1 in b)
self.assert_(0 not in b)
self.assert_(1 in c)
self.assert_(0 not in c)
self.assertRaises(TypeError, lambda: 1 in a)
self.assertRaises(TypeError, lambda: 1 not in a)
check(1 in b, "1 not in set(1)") # test char in string
check(0 not in b, "0 in set(1)") self.assert_('c' in 'abc')
check(1 in c, "1 not in seq(1)") self.assert_('d' not in 'abc')
check(0 not in c, "0 in seq(1)")
try: self.assert_('' in '')
1 in a self.assert_('' in 'abc')
check(0, "in base_set did not raise error")
except TypeError:
pass
try: self.assertRaises(TypeError, lambda: None in 'abc')
1 not in a
check(0, "not in base_set did not raise error")
except TypeError:
pass
# Test char in string if have_unicode:
def test_char_in_unicode(self):
self.assert_('c' in unicode('abc'))
self.assert_('d' not in unicode('abc'))
check('c' in 'abc', "'c' not in 'abc'") self.assert_('' in unicode(''))
check('d' not in 'abc', "'d' in 'abc'") self.assert_(unicode('') in '')
self.assert_(unicode('') in unicode(''))
self.assert_('' in unicode('abc'))
self.assert_(unicode('') in 'abc')
self.assert_(unicode('') in unicode('abc'))
check('' in '', "'' not in ''") self.assertRaises(TypeError, lambda: None in unicode('abc'))
check('' in 'abc', "'' not in 'abc'")
try: # test Unicode char in Unicode
None in 'abc' self.assert_(unicode('c') in unicode('abc'))
check(0, "None in 'abc' did not raise error") self.assert_(unicode('d') not in unicode('abc'))
except TypeError:
pass
# test Unicode char in string
self.assert_(unicode('c') in 'abc')
self.assert_(unicode('d') not in 'abc')
if have_unicode: def test_builtin_sequence_types(self):
# a collection of tests on builtin sequence types
a = range(10)
for i in a:
self.assert_(i in a)
self.assert_(16 not in a)
self.assert_(a not in a)
# Test char in Unicode a = tuple(a)
for i in a:
self.assert_(i in a)
self.assert_(16 not in a)
self.assert_(a not in a)
check('c' in unicode('abc'), "'c' not in u'abc'") class Deviant1:
check('d' not in unicode('abc'), "'d' in u'abc'")
check('' in unicode(''), "'' not in u''")
check(unicode('') in '', "u'' not in ''")
check(unicode('') in unicode(''), "u'' not in u''")
check('' in unicode('abc'), "'' not in u'abc'")
check(unicode('') in 'abc', "u'' not in 'abc'")
check(unicode('') in unicode('abc'), "u'' not in u'abc'")
try:
None in unicode('abc')
check(0, "None in u'abc' did not raise error")
except TypeError:
pass
# Test Unicode char in Unicode
check(unicode('c') in unicode('abc'), "u'c' not in u'abc'")
check(unicode('d') not in unicode('abc'), "u'd' in u'abc'")
# Test Unicode char in string
check(unicode('c') in 'abc', "u'c' not in 'abc'")
check(unicode('d') not in 'abc', "u'd' in 'abc'")
# A collection of tests on builtin sequence types
a = range(10)
for i in a:
check(i in a, "%r not in %r" % (i, a))
check(16 not in a, "16 not in %r" % (a,))
check(a not in a, "%s not in %r" % (a, a))
a = tuple(a)
for i in a:
check(i in a, "%r not in %r" % (i, a))
check(16 not in a, "16 not in %r" % (a,))
check(a not in a, "%r not in %r" % (a, a))
class Deviant1:
"""Behaves strangely when compared """Behaves strangely when compared
This class is designed to make sure that the contains code This class is designed to make sure that the contains code
works when the list is modified during the check. works when the list is modified during the check.
""" """
aList = range(15) aList = range(15)
def __cmp__(self, other): def __cmp__(self, other):
if other == 12: if other == 12:
self.aList.remove(12) self.aList.remove(12)
@ -114,20 +86,26 @@ class Deviant1:
self.aList.remove(14) self.aList.remove(14)
return 1 return 1
check(Deviant1() not in Deviant1.aList, "Deviant1 failed") self.assert_(Deviant1() not in Deviant1.aList)
class Deviant2: class Deviant2:
"""Behaves strangely when compared """Behaves strangely when compared
This class raises an exception during comparison. That in This class raises an exception during comparison. That in
turn causes the comparison to fail with a TypeError. turn causes the comparison to fail with a TypeError.
""" """
def __cmp__(self, other): def __cmp__(self, other):
if other == 4: if other == 4:
raise RuntimeError, "gotcha" raise RuntimeError, "gotcha"
try: try:
check(Deviant2() not in a, "oops") self.assert_(Deviant2() not in a)
except TypeError: except TypeError:
pass pass
def test_main():
run_unittest(TestContains)
if __name__ == '__main__':
test_main()