[Zodb-checkins] SVN: ZODB/branches/3.8/ Bug Fixed: Packing failed for databases containing cross-database references.

Jim Fulton jim at zope.com
Fri May 23 15:52:45 EDT 2008


Log message for revision 86916:
  Bug Fixed: Packing failed for databases containing cross-database references.
  

Changed:
  U   ZODB/branches/3.8/NEWS.txt
  U   ZODB/branches/3.8/src/ZODB/serialize.py
  U   ZODB/branches/3.8/src/ZODB/tests/PackableStorage.py

-=-
Modified: ZODB/branches/3.8/NEWS.txt
===================================================================
--- ZODB/branches/3.8/NEWS.txt	2008-05-23 17:45:56 UTC (rev 86915)
+++ ZODB/branches/3.8/NEWS.txt	2008-05-23 19:52:44 UTC (rev 86916)
@@ -5,6 +5,8 @@
 
 Bugs Fixed:
 
+- (beta 4) Packing failed for databases containing cross-database references.
+
 - (beta 3) Cross-database references to databases with empty names
   weren't constructed properly.
 

Modified: ZODB/branches/3.8/src/ZODB/serialize.py
===================================================================
--- ZODB/branches/3.8/src/ZODB/serialize.py	2008-05-23 17:45:56 UTC (rev 86915)
+++ ZODB/branches/3.8/src/ZODB/serialize.py	2008-05-23 19:52:44 UTC (rev 86916)
@@ -605,17 +605,14 @@
         obj.__setstate__(state)
 
 
-oid_loaders = {
-    'w': lambda oid: None,
-    }
-
 def referencesf(p, oids=None):
     """Return a list of object ids found in a pickle
 
     A list may be passed in, in which case, information is
     appended to it.
 
-    Weak references are not included.
+    Only ordinary internal references are included.
+    Weak and multi-database references are not included.
     """
 
     refs = []
@@ -636,16 +633,10 @@
         elif isinstance(reference, str):
             oid = reference
         else:
-            try:
-                reference_type, args = reference
-            except ValueError:
-                # weakref
-                continue
-            else:
-                oid = oid_loaders[reference_type](*args)
+            assert isinstance(reference, list)
+            continue
 
-        if oid:
-            oids.append(oid)
+        oids.append(oid)
     
     return oids
 
@@ -678,15 +669,9 @@
         elif isinstance(reference, str):
             data = reference, None
         else:
-            try:
-                reference_type, args = reference
-            except ValueError:
-                # weakref
-                continue
-            else:
-                data = oid_klass_loaders[reference_type](*args)
+            assert isinstance(reference, list)
+            continue
 
-        if data:
-            result.append(data)
+        result.append(data)
     
     return result

Modified: ZODB/branches/3.8/src/ZODB/tests/PackableStorage.py
===================================================================
--- ZODB/branches/3.8/src/ZODB/tests/PackableStorage.py	2008-05-23 17:45:56 UTC (rev 86915)
+++ ZODB/branches/3.8/src/ZODB/tests/PackableStorage.py	2008-05-23 19:52:44 UTC (rev 86916)
@@ -38,6 +38,8 @@
 
 from ZODB.tests.MTStorage import TestThread
 
+import ZODB.tests.util
+
 ZERO = '\0'*8
 
 
@@ -311,6 +313,24 @@
                 pass
         it.close()
 
+    def checkPackWithMultiDatabaseReferences(self):
+        databases = {}
+        db = DB(self._storage, databases=databases, database_name='')
+        otherdb = ZODB.tests.util.DB(databases=databases, database_name='o')
+        conn = db.open()
+        root = conn.root()
+        root[1] = C()
+        transaction.commit()
+        del root[1]
+        transaction.commit()
+        root[2] = conn.get_connection('o').root()
+        transaction.commit()
+        db.pack(time.time()+1)
+        assert(len(self._storage) == 1)
+                
+        
+        
+
 class PackableUndoStorage(PackableStorageBase):
 
     def checkPackAllRevisions(self):
@@ -705,3 +725,4 @@
 
     def elapsed_millis(self):
         return int((time.time() - self.start_time) * 1000)
+



More information about the Zodb-checkins mailing list