[Zope-Checkins] CVS: ZODB3/BTrees/tests - testBTrees.py:1.51

Jeremy Hylton jeremy@zope.com
Wed, 23 Apr 2003 15:33:17 -0400


Update of /cvs-repository/ZODB3/BTrees/tests
In directory cvs.zope.org:/tmp/cvs-serv5450

Modified Files:
	testBTrees.py 
Log Message:
Backport simplified versions of BTrees tests from ZOpe3.


=== ZODB3/BTrees/tests/testBTrees.py 1.50 => 1.51 ===
--- ZODB3/BTrees/tests/testBTrees.py:1.50	Fri Jan 31 15:13:03 2003
+++ ZODB3/BTrees/tests/testBTrees.py	Wed Apr 23 15:33:17 2003
@@ -26,85 +26,64 @@
 from glob import glob
 
 from ZODB.tests.StorageTestBase import removefs
+from ZODB import DB
+from ZODB.MappingStorage import MappingStorage
 
 class Base:
     """ Tests common to all types: sets, buckets, and BTrees """
+
+    db = None
+    
     def tearDown(self):
         self.t = None
         del self.t
+        if self.db is not None:
+            self.db.close()
 
     def _getRoot(self):
-        from ZODB.FileStorage import FileStorage
-        from ZODB.DB import DB
-        self._fsname = 'fs_tmp__%s' % os.getpid()
-        s = FileStorage(self._fsname)
-        db = DB(s)
-        root = db.open().root()
-        return root
-
-    def _closeDB(self, root):
-        if root is not None:
-            root._p_jar._db.close()
+        if self.db is None:
+            self.db = DB(MappingStorage())
+        return self.db.open().root()
 
-    def _delDB(self):
-        removefs(self._fsname)
+    def _closeRoot(self, root):
+        root._p_jar.close()
 
     def testLoadAndStore(self):
         for i in 0, 10, 1000:
             t = self.t.__class__()
             self._populate(t, i)
             root = None
-            try:
-                root = self._getRoot()
-                root[i] = t
-                get_transaction().commit()
-            except:
-                self._closeDB(root)
-                self._delDB()
-                raise
-
-            self._closeDB(root)
+            root = self._getRoot()
+            root[i] = t
+            get_transaction().commit()
+
+            root2 = self._getRoot()
+            if hasattr(t, 'items'):
+                self.assertEqual(list(root2[i].items()) , list(t.items()))
+            else:
+                self.assertEqual(list(root2[i].keys()) , list(t.keys()))
 
-            root = None
-            try:
-                root = self._getRoot()
-                #XXX BTree stuff doesn't implement comparison
-                if hasattr(t, 'items'):
-                    self.assertEqual(list(root[i].items()) , list(t.items()))
-                else:
-                    self.assertEqual(list(root[i].keys()) , list(t.keys()))
-            finally:
-                self._closeDB(root)
-                self._delDB()
+            self._closeRoot(root)
+            self._closeRoot(root2)
 
     def testGhostUnghost(self):
         for i in 0, 10, 1000:
             t = self.t.__class__()
             self._populate(t, i)
-            root = None
-            try:
-                root = self._getRoot()
-                root[i] = t
-                get_transaction().commit()
-            except:
-                self._closeDB(root)
-                self._delDB()
-                raise
-
-            self._closeDB(root)
+            root = self._getRoot()
+            root[i] = t
+            get_transaction().commit()
+
+            root2 = self._getRoot()
+            root2[i]._p_deactivate()
+            get_transaction().commit()
+            if hasattr(t, 'items'):
+                self.assertEqual(list(root2[i].items()) , list(t.items()))
+            else:
+                self.assertEqual(list(root2[i].keys()) , list(t.keys()))
 
-            root = None
-            try:
-                root = self._getRoot()
-                root[i]._p_changed = None
-                get_transaction().commit()
-                if hasattr(t,'items'):
-                    self.assertEqual(list(root[i].items()) , list(t.items()))
-                else:
-                    self.assertEqual(list(root[i].keys()) , list(t.keys()))
-            finally:
-                self._closeDB(root)
-                self._delDB()
+            self._closeRoot(root)
+            self._closeRoot(root2)
 
 class MappingBase(Base):
     """ Tests common to mappings (buckets, btrees) """