Commit c06de477 authored by Antoine Pitrou's avatar Antoine Pitrou

Issue #6149: Fix initialization of WeakValueDictionary objects from non-empty parameters.

parent 3b1b8072
......@@ -942,6 +942,17 @@ class MappingTestCase(TestBase):
dict[o] = o.arg
return dict, objects
def test_make_weak_valued_dict_from_dict(self):
o = Object(3)
dict = weakref.WeakValueDictionary({364:o})
self.assertEqual(dict[364], o)
def test_make_weak_valued_dict_from_weak_valued_dict(self):
o = Object(3)
dict = weakref.WeakValueDictionary({364:o})
dict2 = weakref.WeakValueDictionary(dict)
self.assertEqual(dict[364], o)
def make_weak_valued_dict(self):
dict = weakref.WeakValueDictionary()
objects = list(map(Object, range(self.COUNT)))
......
......@@ -49,7 +49,7 @@ class WeakValueDictionary(collections.MutableMapping):
del self.data[wr.key]
self._remove = remove
self.data = d = {}
d.update(*args, **kw)
self.update(*args, **kw)
def __getitem__(self, key):
o = self.data[key]()
......
......@@ -15,6 +15,9 @@ Core and Builtins
Library
-------
- Issue #6149: Fix initialization of WeakValueDictionary objects from non-empty
parameters.
What's New in Python 3.1 release candidate 1?
=============================================
......
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