mirror of
				https://github.com/python/cpython.git
				synced 2025-10-25 18:54:53 +00:00 
			
		
		
		
	Merged revisions 64309 via svnmerge from
svn+ssh://pythondev@svn.python.org/python/trunk ........ r64309 | amaury.forgeotdarc | 2008-06-16 21:12:42 +0200 (lun., 16 juin 2008) | 8 lines Issue 3110: Crash with weakref subclass, seen after a "import multiprocessing.reduction" An instance of a weakref subclass can have attributes. If such a weakref holds the only strong reference to the object, deleting the weakref will delete the object. In this case, the callback must not be called, because the ref object is being deleted! ........
This commit is contained in:
		
							parent
							
								
									27d63678a3
								
							
						
					
					
						commit
						c856c7a2f0
					
				
					 3 changed files with 55 additions and 5 deletions
				
			
		|  | @ -661,7 +661,7 @@ def __del__(self): | |||
|         w = Target() | ||||
| 
 | ||||
| 
 | ||||
| class SubclassableWeakrefTestCase(unittest.TestCase): | ||||
| class SubclassableWeakrefTestCase(TestBase): | ||||
| 
 | ||||
|     def test_subclass_refs(self): | ||||
|         class MyRef(weakref.ref): | ||||
|  | @ -725,6 +725,44 @@ def meth(self): | |||
|         self.assertEqual(r.meth(), "abcdef") | ||||
|         self.failIf(hasattr(r, "__dict__")) | ||||
| 
 | ||||
|     def test_subclass_refs_with_cycle(self): | ||||
|         # Bug #3110 | ||||
|         # An instance of a weakref subclass can have attributes. | ||||
|         # If such a weakref holds the only strong reference to the object, | ||||
|         # deleting the weakref will delete the object. In this case, | ||||
|         # the callback must not be called, because the ref object is | ||||
|         # being deleted. | ||||
|         class MyRef(weakref.ref): | ||||
|             pass | ||||
| 
 | ||||
|         # Use a local callback, for "regrtest -R::" | ||||
|         # to detect refcounting problems | ||||
|         def callback(w): | ||||
|             self.cbcalled += 1 | ||||
| 
 | ||||
|         o = C() | ||||
|         r1 = MyRef(o, callback) | ||||
|         r1.o = o | ||||
|         del o | ||||
| 
 | ||||
|         del r1 # Used to crash here | ||||
| 
 | ||||
|         self.assertEqual(self.cbcalled, 0) | ||||
| 
 | ||||
|         # Same test, with two weakrefs to the same object | ||||
|         # (since code paths are different) | ||||
|         o = C() | ||||
|         r1 = MyRef(o, callback) | ||||
|         r2 = MyRef(o, callback) | ||||
|         r1.r = r2 | ||||
|         r2.o = o | ||||
|         del o | ||||
|         del r2 | ||||
| 
 | ||||
|         del r1 # Used to crash here | ||||
| 
 | ||||
|         self.assertEqual(self.cbcalled, 0) | ||||
| 
 | ||||
| 
 | ||||
| class Object: | ||||
|     def __init__(self, arg): | ||||
|  | @ -1171,6 +1209,7 @@ def test_main(): | |||
|         MappingTestCase, | ||||
|         WeakValueDictionaryTestCase, | ||||
|         WeakKeyDictionaryTestCase, | ||||
|         SubclassableWeakrefTestCase, | ||||
|         ) | ||||
|     support.run_doctest(sys.modules[__name__]) | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Amaury Forgeot d'Arc
						Amaury Forgeot d'Arc