[Zodb-checkins] SVN: ZODB/trunk/src/ Bug Fixed: Deleted records weren't removed when packing file storages.

Jim Fulton jim at zope.com
Mon May 11 17:08:05 EDT 2009


Log message for revision 99856:
  Bug Fixed: Deleted records weren't removed when packing file storages.
  

Changed:
  U   ZODB/trunk/src/CHANGES.txt
  U   ZODB/trunk/src/ZEO/tests/testZEO.py
  U   ZODB/trunk/src/ZODB/FileStorage/fspack.py
  U   ZODB/trunk/src/ZODB/tests/IExternalGC.test
  U   ZODB/trunk/src/ZODB/tests/testFileStorage.py

-=-
Modified: ZODB/trunk/src/CHANGES.txt
===================================================================
--- ZODB/trunk/src/CHANGES.txt	2009-05-11 18:49:48 UTC (rev 99855)
+++ ZODB/trunk/src/CHANGES.txt	2009-05-11 21:08:05 UTC (rev 99856)
@@ -2,6 +2,14 @@
  Change History
 ================
 
+3.9.0b2 (2009-05-??)
+====================
+
+Bugs Fixed
+----------
+
+- Deleted records weren't removed when packing file storages.
+
 3.9.0b1 (2009-05-04)
 ====================
 

Modified: ZODB/trunk/src/ZEO/tests/testZEO.py
===================================================================
--- ZODB/trunk/src/ZEO/tests/testZEO.py	2009-05-11 18:49:48 UTC (rev 99855)
+++ ZODB/trunk/src/ZEO/tests/testZEO.py	2009-05-11 21:08:05 UTC (rev 99856)
@@ -1193,7 +1193,7 @@
         def tpc_abort(self, id):
             self.rpc.call('tpc_abort', id)
 
-    def __init__(self, name, blob_dir, shared=False):
+    def __init__(self, name, blob_dir, shared=False, extrafsoptions=''):
         if shared:
             server_blob_dir = blob_dir
         else:
@@ -1206,9 +1206,10 @@
                 blob-dir %s
                 <filestorage>
                    path %s
+                   %s
                 </filestorage>
             </blobstorage>
-            """ % (server_blob_dir, name+'.fs'),
+            """ % (server_blob_dir, name+'.fs', extrafsoptions),
             port=port,
             )
         os.remove(config)
@@ -1260,7 +1261,8 @@
         )
     zeo.addTest(PackableStorage.IExternalGC_suite(
         lambda :
-        ServerManagingClientStorageForIExternalGCTest('data.fs', 'blobs')
+        ServerManagingClientStorageForIExternalGCTest(
+            'data.fs', 'blobs', extrafsoptions='pack-gc false')
         ))
     for klass in quick_test_classes:
         zeo.addTest(unittest.makeSuite(klass, "check"))

Modified: ZODB/trunk/src/ZODB/FileStorage/fspack.py
===================================================================
--- ZODB/trunk/src/ZODB/FileStorage/fspack.py	2009-05-11 18:49:48 UTC (rev 99855)
+++ ZODB/trunk/src/ZODB/FileStorage/fspack.py	2009-05-11 21:08:05 UTC (rev 99856)
@@ -219,7 +219,11 @@
             while pos < end:
                 dh = self._read_data_header(pos)
                 self.checkData(th, tpos, dh, pos)
-                self.oid2curpos[dh.oid] = pos
+                if dh.plen or dh.back:
+                    self.oid2curpos[dh.oid] = pos
+                else:
+                    if dh.oid in self.oid2curpos:
+                        del self.oid2curpos[dh.oid]
                 pos += dh.recordlen()
 
             tlen = self._read_num(pos)

Modified: ZODB/trunk/src/ZODB/tests/IExternalGC.test
===================================================================
--- ZODB/trunk/src/ZODB/tests/IExternalGC.test	2009-05-11 18:49:48 UTC (rev 99855)
+++ ZODB/trunk/src/ZODB/tests/IExternalGC.test	2009-05-11 21:08:05 UTC (rev 99856)
@@ -25,6 +25,18 @@
     >>> p0, s0 = storage.load(oid0, '')
     >>> p1, s1 = storage.load(oid1, '')
 
+The storage is configured not to gc on pack, so even if we pack, these
+objects won't go away:
+
+    >>> len(storage)
+    3
+    >>> import time
+    >>> db.pack(time.time()+1)
+    >>> len(storage)
+    3
+    >>> p0, s0 = storage.load(oid0, '')
+    >>> p1, s1 = storage.load(oid1, '')
+
 Now we'll use the new deleteObject API to delete the objects. We can't
 go through the database to do this, so we'll have to manage the
 transaction ourselves.
@@ -62,12 +74,12 @@
 If we pack, however, the old data will be removed and the data will be
 gone:
 
-    >>> import time
     >>> db.pack(time.time()+1)
+    >>> len(db.storage)
+    1
 
+    >>> time.sleep(.1)
 
->>> time.sleep(1)
-
     >>> storage.load(oid0, '') # doctest: +ELLIPSIS
     Traceback (most recent call last):
     ...

Modified: ZODB/trunk/src/ZODB/tests/testFileStorage.py
===================================================================
--- ZODB/trunk/src/ZODB/tests/testFileStorage.py	2009-05-11 18:49:48 UTC (rev 99855)
+++ ZODB/trunk/src/ZODB/tests/testFileStorage.py	2009-05-11 21:08:05 UTC (rev 99856)
@@ -587,7 +587,8 @@
         test_packing=True,
         ))
     suite.addTest(PackableStorage.IExternalGC_suite(
-        lambda : ZODB.FileStorage.FileStorage('data.fs', blob_dir='blobs')))
+        lambda : ZODB.FileStorage.FileStorage(
+            'data.fs', blob_dir='blobs', pack_gc=False)))
     return suite
 
 if __name__=='__main__':



More information about the Zodb-checkins mailing list