add 'cache' property
This commit is contained in:
@ -4,7 +4,7 @@ from tiramisu import setting
|
||||
setting.expires_time = 1
|
||||
from tiramisu.option import IntOption, OptionDescription
|
||||
from tiramisu.config import Config
|
||||
from time import sleep
|
||||
from time import sleep, time
|
||||
|
||||
|
||||
def make_description():
|
||||
@ -20,13 +20,26 @@ def test_cache():
|
||||
values = c.cfgimpl_get_values()
|
||||
settings = c.cfgimpl_get_settings()
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
c.u2
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u2' in values._p_.get_cached('value', c)
|
||||
assert 'u2' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
assert 'u2' in values._p_.get_cached(c)
|
||||
assert 'u2' in settings._p_.get_cached(c)
|
||||
|
||||
|
||||
def test_get_cache():
|
||||
# force a value in cache, try if reget corrupted value
|
||||
od1 = make_description()
|
||||
c = Config(od1)
|
||||
values = c.cfgimpl_get_values()
|
||||
settings = c.cfgimpl_get_settings()
|
||||
ntime = time() + 1
|
||||
settings._p_.setcache('u1', set(['inject']), ntime)
|
||||
assert 'inject' in settings[od1.u1]
|
||||
values._p_.setcache('u1', 100, ntime)
|
||||
assert c.u1 == [100]
|
||||
|
||||
|
||||
def test_cache_reset():
|
||||
@ -36,44 +49,44 @@ def test_cache_reset():
|
||||
settings = c.cfgimpl_get_settings()
|
||||
#when change a value
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
c.u2 = 1
|
||||
assert 'u1' not in values._p_.get_cached('value', c)
|
||||
assert 'u1' not in settings._p_.get_cached('property', c)
|
||||
assert 'u1' not in values._p_.get_cached(c)
|
||||
assert 'u1' not in settings._p_.get_cached(c)
|
||||
#when remove a value
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
del(c.u2)
|
||||
assert 'u1' not in values._p_.get_cached('value', c)
|
||||
assert 'u1' not in settings._p_.get_cached('property', c)
|
||||
assert 'u1' not in values._p_.get_cached(c)
|
||||
assert 'u1' not in settings._p_.get_cached(c)
|
||||
#when add/del property
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
c.cfgimpl_get_settings()[od1.u2].append('test')
|
||||
assert 'u1' not in values._p_.get_cached('value', c)
|
||||
assert 'u1' not in settings._p_.get_cached('property', c)
|
||||
assert 'u1' not in values._p_.get_cached(c)
|
||||
assert 'u1' not in settings._p_.get_cached(c)
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
c.cfgimpl_get_settings()[od1.u2].remove('test')
|
||||
assert 'u1' not in values._p_.get_cached('value', c)
|
||||
assert 'u1' not in settings._p_.get_cached('property', c)
|
||||
assert 'u1' not in values._p_.get_cached(c)
|
||||
assert 'u1' not in settings._p_.get_cached(c)
|
||||
#when enable/disabled property
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
c.cfgimpl_get_settings().append('test')
|
||||
assert 'u1' not in values._p_.get_cached('value', c)
|
||||
assert 'u1' not in settings._p_.get_cached('property', c)
|
||||
assert 'u1' not in values._p_.get_cached(c)
|
||||
assert 'u1' not in settings._p_.get_cached(c)
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
c.cfgimpl_get_settings().remove('test')
|
||||
assert 'u1' not in values._p_.get_cached('value', c)
|
||||
assert 'u1' not in settings._p_.get_cached('property', c)
|
||||
assert 'u1' not in values._p_.get_cached(c)
|
||||
assert 'u1' not in settings._p_.get_cached(c)
|
||||
|
||||
|
||||
def test_cache_reset_multi():
|
||||
@ -83,32 +96,32 @@ def test_cache_reset_multi():
|
||||
settings = c.cfgimpl_get_settings()
|
||||
#when change a value
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
c.u3 = [1]
|
||||
assert 'u1' not in values._p_.get_cached('value', c)
|
||||
assert 'u1' not in settings._p_.get_cached('property', c)
|
||||
assert 'u1' not in values._p_.get_cached(c)
|
||||
assert 'u1' not in settings._p_.get_cached(c)
|
||||
#when append value
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
c.u3.append(1)
|
||||
assert 'u1' not in values._p_.get_cached('value', c)
|
||||
assert 'u1' not in settings._p_.get_cached('property', c)
|
||||
assert 'u1' not in values._p_.get_cached(c)
|
||||
assert 'u1' not in settings._p_.get_cached(c)
|
||||
#when pop value
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
c.u3.pop(1)
|
||||
assert 'u1' not in values._p_.get_cached('value', c)
|
||||
assert 'u1' not in settings._p_.get_cached('property', c)
|
||||
assert 'u1' not in values._p_.get_cached(c)
|
||||
assert 'u1' not in settings._p_.get_cached(c)
|
||||
#when remove a value
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
del(c.u3)
|
||||
assert 'u1' not in values._p_.get_cached('value', c)
|
||||
assert 'u1' not in settings._p_.get_cached('property', c)
|
||||
assert 'u1' not in values._p_.get_cached(c)
|
||||
assert 'u1' not in settings._p_.get_cached(c)
|
||||
|
||||
|
||||
def test_reset_cache():
|
||||
@ -117,23 +130,25 @@ def test_reset_cache():
|
||||
values = c.cfgimpl_get_values()
|
||||
settings = c.cfgimpl_get_settings()
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
c.cfgimpl_reset_cache()
|
||||
assert 'u1' not in values._p_.get_cached('value', c)
|
||||
assert 'u1' not in settings._p_.get_cached('property', c)
|
||||
assert 'u1' not in values._p_.get_cached(c)
|
||||
assert 'u1' not in settings._p_.get_cached(c)
|
||||
c.u1
|
||||
sleep(1)
|
||||
c.u1
|
||||
sleep(1)
|
||||
c.u2
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u2' in values._p_.get_cached('value', c)
|
||||
assert 'u2' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
assert 'u2' in values._p_.get_cached(c)
|
||||
assert 'u2' in settings._p_.get_cached(c)
|
||||
c.cfgimpl_reset_cache()
|
||||
assert 'u1' not in values._p_.get_cached('value', c)
|
||||
assert 'u1' not in settings._p_.get_cached('property', c)
|
||||
assert 'u2' not in values._p_.get_cached('value', c)
|
||||
assert 'u2' not in settings._p_.get_cached('property', c)
|
||||
assert 'u1' not in values._p_.get_cached(c)
|
||||
assert 'u1' not in settings._p_.get_cached(c)
|
||||
assert 'u2' not in values._p_.get_cached(c)
|
||||
assert 'u2' not in settings._p_.get_cached(c)
|
||||
|
||||
|
||||
def test_reset_cache_subconfig():
|
||||
@ -142,9 +157,9 @@ def test_reset_cache_subconfig():
|
||||
c = Config(od2)
|
||||
values = c.cfgimpl_get_values()
|
||||
c.od1.u1
|
||||
assert 'od1.u1' in values._p_.get_cached('value', c)
|
||||
assert 'od1.u1' in values._p_.get_cached(c)
|
||||
c.od1.cfgimpl_reset_cache()
|
||||
assert 'od1.u1' not in values._p_.get_cached('value', c)
|
||||
assert 'od1.u1' not in values._p_.get_cached(c)
|
||||
|
||||
|
||||
def test_reset_cache_only_expired():
|
||||
@ -153,22 +168,60 @@ def test_reset_cache_only_expired():
|
||||
values = c.cfgimpl_get_values()
|
||||
settings = c.cfgimpl_get_settings()
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
c.cfgimpl_reset_cache(True)
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
sleep(1)
|
||||
c.u1
|
||||
sleep(1)
|
||||
c.u2
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u2' in values._p_.get_cached('value', c)
|
||||
assert 'u2' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
assert 'u2' in values._p_.get_cached(c)
|
||||
assert 'u2' in settings._p_.get_cached(c)
|
||||
c.cfgimpl_reset_cache(True)
|
||||
assert 'u1' not in values._p_.get_cached('value', c)
|
||||
assert 'u1' not in settings._p_.get_cached('property', c)
|
||||
assert 'u2' in values._p_.get_cached('value', c)
|
||||
assert 'u2' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' not in values._p_.get_cached(c)
|
||||
assert 'u1' not in settings._p_.get_cached(c)
|
||||
assert 'u2' in values._p_.get_cached(c)
|
||||
assert 'u2' in settings._p_.get_cached(c)
|
||||
|
||||
|
||||
def test_cache_not_expire():
|
||||
od1 = make_description()
|
||||
c = Config(od1)
|
||||
values = c.cfgimpl_get_values()
|
||||
settings = c.cfgimpl_get_settings()
|
||||
settings.remove('expire')
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
c.cfgimpl_reset_cache(True)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
sleep(1)
|
||||
c.u2
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
assert 'u2' in values._p_.get_cached(c)
|
||||
assert 'u2' in settings._p_.get_cached(c)
|
||||
c.cfgimpl_reset_cache(True)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
assert 'u2' in values._p_.get_cached(c)
|
||||
assert 'u2' in settings._p_.get_cached(c)
|
||||
|
||||
|
||||
def test_cache_not_cache():
|
||||
od1 = make_description()
|
||||
c = Config(od1)
|
||||
values = c.cfgimpl_get_values()
|
||||
settings = c.cfgimpl_get_settings()
|
||||
settings.remove('cache')
|
||||
c.u1
|
||||
assert 'u1' not in values._p_.get_cached(c)
|
||||
assert 'u1' not in settings._p_.get_cached(c)
|
||||
|
||||
|
||||
def test_reset_cache_only():
|
||||
@ -177,14 +230,14 @@ def test_reset_cache_only():
|
||||
values = c.cfgimpl_get_values()
|
||||
settings = c.cfgimpl_get_settings()
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
c.cfgimpl_reset_cache(only=('values',))
|
||||
assert 'u1' not in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' not in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
c.u1
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' in settings._p_.get_cached(c)
|
||||
c.cfgimpl_reset_cache(only=('settings',))
|
||||
assert 'u1' in values._p_.get_cached('value', c)
|
||||
assert 'u1' not in settings._p_.get_cached('property', c)
|
||||
assert 'u1' in values._p_.get_cached(c)
|
||||
assert 'u1' not in settings._p_.get_cached(c)
|
||||
|
Reference in New Issue
Block a user