Closes SF bug #628246.

The _update method detected mutable elements by trapping TypeErrors.
Unfortunately, this masked useful TypeErrors raised by the iterable
itself.  For cases where it is possible for an iterable to raise
a TypeError, the iterable is pre-converted to a list outside the
try/except so that any TypeErrors propagate through.
This commit is contained in:
Raymond Hettinger 2002-11-08 05:03:21 +00:00
parent dde800ec4e
commit 1eb1fb814b
2 changed files with 27 additions and 0 deletions

View File

@ -320,6 +320,8 @@ class BaseSet(object):
return
value = True
if type(iterable) not in (list, tuple, dict, file, xrange, str):
iterable = list(iterable)
it = iter(iterable)
while True:
try:

View File

@ -132,6 +132,30 @@ class TestBasicOpsTriple(TestBasicOps):
#==============================================================================
def baditer():
raise TypeError
yield True
def gooditer():
yield True
class TestExceptionPropagation(unittest.TestCase):
"""SF 628246: Set constructor should not trap iterator TypeErrors"""
def test_instanceWithException(self):
self.assertRaises(TypeError, Set, baditer())
def test_instancesWithoutException(self):
"""All of these iterables should load without exception."""
Set([1,2,3])
Set((1,2,3))
Set({'one':1, 'two':2, 'three':3})
Set(xrange(3))
Set('abc')
Set(gooditer())
#==============================================================================
class TestSetOfSets(unittest.TestCase):
def test_constructor(self):
inner = Set([1])
@ -604,6 +628,7 @@ class TestCopyingNested(TestCopying):
def makeAllTests():
suite = unittest.TestSuite()
for klass in (TestSetOfSets,
TestExceptionPropagation,
TestBasicOpsEmpty,
TestBasicOpsSingleton,
TestBasicOpsTuple,