[Zodb-checkins] CVS: Zope/lib/python/ZODB/tests - test_cache.py:1.2

Jeremy Hylton jeremy at zope.com
Tue Mar 2 11:44:00 EST 2004


Update of /cvs-repository/Zope/lib/python/ZODB/tests
In directory cvs.zope.org:/tmp/cvs-serv15192

Modified Files:
	test_cache.py 
Log Message:
Add another test of the basic cache methods.


=== Zope/lib/python/ZODB/tests/test_cache.py 1.1 => 1.2 ===
--- Zope/lib/python/ZODB/tests/test_cache.py:1.1	Tue Mar  2 11:25:21 2004
+++ Zope/lib/python/ZODB/tests/test_cache.py	Tue Mar  2 11:43:58 2004
@@ -49,10 +49,82 @@
     def _p_deactivate(self):
         self.__class__.deactivations += 1
 
+class RegularObject(Persistent):
+
+    deactivations = 0
+    invalidations = 0
+
+    def _p_deactivate(self):
+        self.__class__.deactivations += 1
+        super(RegularObject, self)._p_deactivate()
+
+    def _p_invalidate(self):
+        self.__class__.invalidations += 1
+        super(RegularObject, self)._p_invalidate()
+
 class CacheTests(unittest.TestCase):
 
     def test_cache(self):
-        pass
+        r"""Test basic cache methods.
+        
+        >>> db = databaseFromString("<zodb>\n"
+        ...                         "cache-size 4\n"
+        ...                         "<mappingstorage/>\n"
+        ...                         "</zodb>")
+        >>> cn = db.open()
+        >>> r = cn.root()
+        >>> L = []
+        >>> for i in range(5):
+        ...     o = RegularObject()
+        ...     L.append(o)
+        ...     r[i] = o
+        >>> get_transaction().commit()
+
+        After committing a transaction and calling cacheGC(), there
+        should be cache-size (4) objects in the cache.  One of the
+        RegularObjects was deactivated.
+        
+        >>> cn._cache.ringlen()
+        4
+        >>> RegularObject.deactivations
+        1
+
+        If we explicitly activate the objects again, the ringlen
+        should go back up to 5.
+        
+        >>> for o in L:
+        ...     o._p_activate()
+        >>> cn._cache.ringlen()
+        5
+
+        >>> cn.cacheGC()
+        >>> cn._cache.ringlen()
+        4
+        >>> RegularObject.deactivations
+        2
+        
+        >>> cn.cacheMinimize()
+        >>> cn._cache.ringlen()
+        0
+        >>> RegularObject.deactivations
+        6
+
+        If we activate all the objects again and mark one as modified,
+        then the one object should not be deactivated even by a
+        minimize.
+        
+        >>> for o in L:
+        ...     o._p_activate()
+        >>> o.attr = 1  
+        >>> cn._cache.ringlen()
+        5
+        >>> cn.cacheMinimize()
+        >>> cn._cache.ringlen()
+        1
+        >>> RegularObject.deactivations
+        10
+        
+        """
 
     def test_cache_gc_recalcitrant(self):
         r"""Test that a cacheGC() call will return.




More information about the Zodb-checkins mailing list