[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