[Zope-Checkins] CVS: Zope/lib/python/ZEO/tests - testClientCache.py:1.8
Shane Hathaway
shane@zope.com
Tue, 10 Jun 2003 13:08:11 -0400
Update of /cvs-repository/Zope/lib/python/ZEO/tests
In directory cvs.zope.org:/tmp/cvs-serv11919/tests
Modified Files:
testClientCache.py
Log Message:
Merged shane-oid-length-branch.
The ZEO client cache now works with OIDs of length up to 65535 bytes.
Also added some sanity checks that check the size of the data being written,
since there are some hard limits.
=== Zope/lib/python/ZEO/tests/testClientCache.py 1.7 => 1.8 ===
--- Zope/lib/python/ZEO/tests/testClientCache.py:1.7 Fri Jan 3 17:07:40 2003
+++ Zope/lib/python/ZEO/tests/testClientCache.py Tue Jun 10 13:08:10 2003
@@ -27,6 +27,10 @@
class ClientCacheTests(unittest.TestCase):
+ _oid = 'abcdefgh'
+ _oid2 = 'bcdefghi'
+ _oid3 = 'cdefghij'
+
def setUp(self):
unittest.TestCase.setUp(self)
self.cachesize = 10*1000*1000
@@ -42,7 +46,7 @@
def testStoreLoad(self):
cache = self.cache
- oid = 'abcdefgh'
+ oid = self._oid
data = '1234'*100
serial = 'ABCDEFGH'
cache.store(oid, data, serial, '', '', '')
@@ -51,7 +55,7 @@
def testMissingLoad(self):
cache = self.cache
- oid = 'abcdefgh'
+ oid = self._oid
data = '1234'*100
serial = 'ABCDEFGH'
cache.store(oid, data, serial, '', '', '')
@@ -60,7 +64,7 @@
def testInvalidate(self):
cache = self.cache
- oid = 'abcdefgh'
+ oid = self._oid
data = '1234'*100
serial = 'ABCDEFGH'
cache.store(oid, data, serial, '', '', '')
@@ -72,7 +76,7 @@
def testVersion(self):
cache = self.cache
- oid = 'abcdefgh'
+ oid = self._oid
data = '1234'*100
serial = 'ABCDEFGH'
vname = 'myversion'
@@ -86,7 +90,7 @@
def testVersionOnly(self):
cache = self.cache
- oid = 'abcdefgh'
+ oid = self._oid
data = ''
serial = ''
vname = 'myversion'
@@ -100,7 +104,7 @@
def testInvalidateNonVersion(self):
cache = self.cache
- oid = 'abcdefgh'
+ oid = self._oid
data = '1234'*100
serial = 'ABCDEFGH'
vname = 'myversion'
@@ -122,7 +126,7 @@
# Invalidating a version should not invalidate the non-version data.
# (This tests for the same bug as testInvalidatePersists below.)
cache = self.cache
- oid = 'abcdefgh'
+ oid = self._oid
data = '1234'*100
serial = 'ABCDEFGH'
cache.store(oid, data, serial, '', '', '')
@@ -139,7 +143,7 @@
results.append((oid, serial, vserial))
cache.verify(verifier)
self.assertEqual(results, [])
- oid = 'abcdefgh'
+ oid = self._oid
data = '1234'*100
serial = 'ABCDEFGH'
cache.store(oid, data, serial, '', '', '')
@@ -151,12 +155,12 @@
# Make sure that cache._index[oid] is erased for oids that are
# stored in the cache file that's rewritten after a flip.
cache = self.cache
- oid = 'abcdefgh'
+ oid = self._oid
data = '1234'*100
serial = 'ABCDEFGH'
cache.store(oid, data, serial, '', '', '')
cache.checkSize(10*self.cachesize) # Force a file flip
- oid2 = 'abcdefgz'
+ oid2 = self._oid2
data2 = '1234'*10
serial2 = 'ABCDEFGZ'
cache.store(oid2, data2, serial2, '', '', '')
@@ -178,17 +182,17 @@
cache = self.cache
# Create some objects
- oid1 = 'abcdefgh'
+ oid1 = self._oid
data1 = '1234' * 100
serial1 = 'ABCDEFGH'
- oid2 = 'bcdefghi'
+ oid2 = self._oid2
data2 = '2345' * 200
serial2 = 'BCDEFGHI'
version2 = 'myversion'
nonversion = 'nada'
vdata2 = '5432' * 250
vserial2 = 'IHGFEDCB'
- oid3 = 'cdefghij'
+ oid3 = self._oid3
data3 = '3456' * 300
serial3 = 'CDEFGHIJ'
@@ -276,6 +280,8 @@
class PersistentClientCacheTests(unittest.TestCase):
+ _oid = 'abcdefgh'
+
def setUp(self):
unittest.TestCase.setUp(self)
self.vardir = os.getcwd() # Don't use /tmp, it's a security risk
@@ -323,13 +329,12 @@
# 'current' file when a persistent cache was opened.
cache = self.cache
self.assertEqual(cache._current, 0) # Check that file 0 is current
- oid = 'abcdefgh'
+ oid = self._oid
data = '1234'
serial = 'ABCDEFGH'
cache.store(oid, data, serial, '', '', '')
cache.checkSize(10*self.cachesize) # Force a file flip
self.assertEqual(cache._current, 1) # Check that the flip worked
- oid = 'abcdefgh'
data = '123'
serial = 'ABCDEFGZ'
cache.store(oid, data, serial, '', '', '')
@@ -348,7 +353,7 @@
cache = self.cache
magicsize = (ord('i') + 1) << 16
cache = self.cache
- oid = 'abcdefgh'
+ oid = self._oid
data = '!'*magicsize
serial = 'ABCDEFGH'
cache.store(oid, data, serial, '', '', '')
@@ -367,7 +372,7 @@
ltid = 'pqrstuvw'
cache.setLastTid(ltid)
self.assertEqual(cache.getLastTid(), ltid)
- oid = 'abcdefgh'
+ oid = self._oid
data = '1234'
serial = 'ABCDEFGH'
cache.store(oid, data, serial, '', '', '')
@@ -381,10 +386,23 @@
cache.checkSize(10*self.cachesize) # Force a file flip
self.failUnless(cache.getLastTid() is None)
+
+class ClientCacheLongOIDTests(ClientCacheTests):
+ _oid = 'abcdefghijklmnop' * 2
+ _oid2 = 'bcdefghijklmnopq' * 2
+ _oid3 = 'cdefghijklmnopqr' * 2
+
+
+class PersistentClientCacheLongOIDTests(PersistentClientCacheTests):
+ _oid = 'abcdefghijklmnop' * 2
+
+
def test_suite():
suite = unittest.TestSuite()
suite.addTest(unittest.makeSuite(ClientCacheTests))
+ suite.addTest(unittest.makeSuite(ClientCacheLongOIDTests))
suite.addTest(unittest.makeSuite(PersistentClientCacheTests))
+ suite.addTest(unittest.makeSuite(PersistentClientCacheLongOIDTests))
return suite
if __name__ == '__main__':