Commit e02d03a6 authored by Jérome Perrin's avatar Jérome Perrin

testCache was not started due to import errors


git-svn-id: https://svn.erp5.org/repos/public/erp5/trunk@11491 20353a03-c40f-0410-a6d1-a30d3c3de9de
parent 2f62eee8
No related merge requests found
......@@ -29,28 +29,34 @@
import random
import unittest
import time
import base64, md5
from ERP5Type.CachePlugins.RamCache import RamCache
from ERP5Type.CachePlugins.DistributedRamCache import DistributedRamCache
from ERP5Type.CachePlugins.SQLCache import SQLCache
from ERP5Type.CachePlugins.BaseCache import CacheEntry
import os
from Products.ERP5Type.CachePlugins.RamCache import RamCache
from Products.ERP5Type.CachePlugins.DistributedRamCache import\
DistributedRamCache
from Products.ERP5Type.CachePlugins.SQLCache import SQLCache
from Products.ERP5Type.CachePlugins.BaseCache import CacheEntry
from Products.ERP5Type.Tool.CacheTool import CacheTool
class Foo:
my_field = (1,2,3,4,5)
class TestRamCache(unittest.TestCase):
quiet = 1
def setUp(self):
# for SQLCache, get the connection string from runUnitTest.py parameters,
# and use parseDBConnectionString to make it usable by SQLCache
mysql_connection_string = os.environ.get(
'erp5_sql_connection_string', 'test test')
sql_cache_kw = CacheTool().parseDBConnectionString(mysql_connection_string)
sql_cache_kw['cache_table_name'] = 'cache'
self.cache_plugins = (RamCache(),
DistributedRamCache({'servers': '127.0.0.1:11211',
'debugLevel': 7,}),
SQLCache( {'server': '',
'user': '',
'passwd': '',
'db': 'test',
'cache_table_name': 'cache',
}),
SQLCache( sql_cache_kw ),
)
def testScope(self):
......@@ -63,9 +69,11 @@ class TestRamCache(unittest.TestCase):
test_scopes.sort()
## remove DistributedRamCache since it's a flat storage
filtered_cache_plugins = filter(lambda x: not isinstance(x, DistributedRamCache), self.cache_plugins)
filtered_cache_plugins = filter(
lambda x: not isinstance(x, DistributedRamCache), self.cache_plugins)
for cache_plugin in filtered_cache_plugins:
if not self.quiet:
print "TESTING (scope): ", cache_plugin
## clear cache for this plugin
......@@ -81,6 +89,7 @@ class TestRamCache(unittest.TestCase):
## we set ONLY one value per scope -> check if we get the same cache_id
self.assertEqual([cache_id], cache_plugin.getScopeKeyList(scope))
if not self.quiet:
print "\t", cache_id, scope, "\t\tOK"
## get list of scopes which must be the same as test_scopes since we clear cache initially
......@@ -108,12 +117,14 @@ class TestRamCache(unittest.TestCase):
self.generaltestSetGet(cache_plugin, 100)
def testExpire(self):
""" Check expired by setting a key, wit for its timeout and check if in cache"""
""" Check expired by setting a key, wit for its timeout and check if in
cache"""
for cache_plugin in self.cache_plugins:
self.generalExpire(cache_plugin, 2)
def generalExpire(self, cache_plugin, iterations):
if not self.quiet:
print "TESTING (expire): ", cache_plugin
base_timeout = 1
values = self.prepareValues(iterations)
......@@ -123,6 +134,7 @@ class TestRamCache(unittest.TestCase):
count = count +1
cache_timeout = base_timeout + random.random()*2
cache_id = "mycache_id_to_expire_%s" %(count)
if not self.quiet:
print "\t", cache_id, " ==> timeout (s) = ", cache_timeout,
## set to cache
......@@ -136,9 +148,11 @@ class TestRamCache(unittest.TestCase):
## check it, we MUST NOT have this key any more in cache
self.assertEqual(False, cache_plugin.has_key(cache_id, scope))
if not self.quiet:
print "\t\tOK"
def generaltestSetGet(self, cache_plugin, iterations):
if not self.quiet:
print "TESTING (set/get/has/del): ", cache_plugin
values = self.prepareValues(iterations)
cache_duration = 30
......@@ -150,6 +164,7 @@ class TestRamCache(unittest.TestCase):
## set to cache
cache_plugin.set(cache_id, scope, value, cache_duration)
if not self.quiet:
print "\t", cache_id,
## check has_key()
......@@ -175,6 +190,7 @@ class TestRamCache(unittest.TestCase):
cache_plugin.delete(cache_id, scope)
self.assertEqual(False, cache_plugin.has_key(cache_id, scope))
if not self.quiet:
print "\t\tOK"
def prepareValues(self, iterations):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment