Kaydet (Commit) 1eb1fb81 authored tarafından Raymond Hettinger's avatar Raymond Hettinger

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.
üst dde800ec
......@@ -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,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment