mirror of https://github.com/python/cpython
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:
parent
dde800ec4e
commit
1eb1fb814b
|
@ -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:
|
||||
|
|
|
@ -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,
|
||||
|
|
Loading…
Reference in New Issue