[Zodb-checkins] SVN: ZODB/trunk/src/ Fixed a bug in ZEO client cache simulation that caused invalidations
Jim Fulton
jim at zope.com
Tue Oct 26 15:22:34 EDT 2010
Log message for revision 117931:
Fixed a bug in ZEO client cache simulation that caused invalidations
to be misshandled, causing incorrect statistics and errors.
Changed:
U ZODB/trunk/src/CHANGES.txt
U ZODB/trunk/src/ZEO/scripts/cache_simul.py
U ZODB/trunk/src/ZEO/tests/test_cache.py
-=-
Modified: ZODB/trunk/src/CHANGES.txt
===================================================================
--- ZODB/trunk/src/CHANGES.txt 2010-10-26 19:15:47 UTC (rev 117930)
+++ ZODB/trunk/src/CHANGES.txt 2010-10-26 19:22:34 UTC (rev 117931)
@@ -25,6 +25,9 @@
don't send invalidations. There's no reason to send them when an
external garbage collector is used.
+- ZEO client cache simulation misshandled invalidations
+ causing incorrect statistics and errors.
+
3.10.0 (2010-10-08)
===================
Modified: ZODB/trunk/src/ZEO/scripts/cache_simul.py
===================================================================
--- ZODB/trunk/src/ZEO/scripts/cache_simul.py 2010-10-26 19:15:47 UTC (rev 117930)
+++ ZODB/trunk/src/ZEO/scripts/cache_simul.py 2010-10-26 19:22:34 UTC (rev 117931)
@@ -252,6 +252,8 @@
nreports = 0
def report(self):
+ if not hasattr(self, 'ts1'):
+ return
self.nreports += 1
args = (ctime(self.ts0)[4:-8],
duration(self.ts1 - self.ts0),
@@ -417,6 +419,9 @@
# about this oid.
self._remove_noncurrent_revisions(oid)
+ if oid in self.evicted:
+ del self.evicted[oid]
+
cur_tid = self.current.get(oid)
if cur_tid is None:
# We don't have current data, so nothing more to do.
Modified: ZODB/trunk/src/ZEO/tests/test_cache.py
===================================================================
--- ZODB/trunk/src/ZEO/tests/test_cache.py 2010-10-26 19:15:47 UTC (rev 117930)
+++ ZODB/trunk/src/ZEO/tests/test_cache.py 2010-10-26 19:22:34 UTC (rev 117931)
@@ -1028,6 +1028,36 @@
"""
+def cache_simul_properly_handles_load_miss_after_eviction_and_inval():
+ r"""
+
+Set up evicted and then invalidated oid
+
+ >>> os.environ["ZEO_CACHE_TRACE"] = 'yes'
+ >>> cache = ZEO.cache.ClientCache('cache', 1<<21)
+ >>> cache.store(p64(1), p64(1), None, 'x')
+ >>> for i in range(10):
+ ... cache.store(p64(2+i), p64(1), None, 'x'*(1<<19)) # Evict 1
+ >>> cache.store(p64(1), p64(1), None, 'x')
+ >>> cache.invalidate(p64(1), p64(2))
+ >>> cache.load(p64(1))
+ >>> cache.close()
+
+Now try to do simulation:
+
+ >>> import ZEO.scripts.cache_simul
+ >>> ZEO.scripts.cache_simul.main('-s 1 cache.trace'.split())
+ ... # doctest: +ELLIPSIS +NORMALIZE_WHITESPACE
+ CircularCacheSimulation, cache size 1,048,576 bytes
+ START TIME DUR. LOADS HITS INVALS WRITES HITRATE EVICTS INUSE
+ ... 0 1 0 1 12 0.0% 10 50.0
+ --------------------------------------------------------------------------
+ ... 0 1 0 1 12 0.0% 10 50.0
+
+ >>> del os.environ["ZEO_CACHE_TRACE"]
+
+ """
+
def invalidations_with_current_tid_dont_wreck_cache():
"""
>>> cache = ZEO.cache.ClientCache('cache', 1000)
More information about the Zodb-checkins
mailing list