[Zope-Checkins] CVS: StandaloneZODB/BTrees/tests - testBTrees.py:1.26

Guido van Rossum guido@python.org
Fri, 25 Jan 2002 16:04:26 -0500


Update of /cvs-repository/StandaloneZODB/BTrees/tests
In directory cvs.zope.org:/tmp/cvs-serv11611

Modified Files:
	testBTrees.py 
Log Message:
Fix a problem I saw when some tests here failed: there's a pattern in
the code

    try:
        root = self._getRoot()
        ...
    except:
        self._closeDB(root)
	self._delDB()
	raise

which fails with an UnboundLocalError if the first line in the try
clause fails.  Fixed this by setting 'root = None' before each such
try clause, and adding a None check to _closeDB().  Also removed a
useless 'root = None' from the body of _closeDB().

Barry: I saw this in the saz 1.0c1 release.  Is it worth backporting?
Probably not given that we're not going to do a merge pre-1.0.


=== StandaloneZODB/BTrees/tests/testBTrees.py 1.25 => 1.26 ===
 
     def _closeDB(self, root):
-        root._p_jar._db.close()
-        root = None
+        if root is not None:
+            root._p_jar._db.close()
 
     def _delDB(self):
         for file in glob('fs_tmp__*'):
@@ -48,6 +48,7 @@
         for i in 0, 10, 1000:
             t = self.t.__class__()
             self._populate(t, i)
+            root = None
             try:
                 root = self._getRoot()
                 root[i] = t
@@ -59,6 +60,7 @@
 
             self._closeDB(root)
 
+            root = None
             try:
                 root = self._getRoot()
                 #XXX BTree stuff doesn't implement comparison
@@ -74,6 +76,7 @@
         for i in 0, 10, 1000:
             t = self.t.__class__()
             self._populate(t, i)
+            root = None
             try:
                 root = self._getRoot()
                 root[i] = t
@@ -85,6 +88,7 @@
 
             self._closeDB(root)
 
+            root = None
             try:
                 root = self._getRoot()
                 root[i]._p_changed = None