846 lines
42 KiB
Python
846 lines
42 KiB
Python
"config.set() or config.setoption() or option.setoption()"
|
|
from .autopath import do_autopath
|
|
do_autopath()
|
|
from .config import config_type, get_config
|
|
|
|
import pytest
|
|
from os import environ
|
|
|
|
from tiramisu.i18n import _
|
|
from tiramisu.error import display_list, ConfigError
|
|
from tiramisu.setting import owners, groups
|
|
from tiramisu import ChoiceOption, BoolOption, IntOption, FloatOption, \
|
|
StrOption, OptionDescription, Leadership, Config, undefined, \
|
|
Calculation, Params, ParamOption, ParamValue, ParamIndex, \
|
|
calc_value, calc_value_property_help
|
|
from tiramisu.error import PropertiesOptionError
|
|
from tiramisu.storage import list_sessions
|
|
import warnings
|
|
|
|
|
|
def teardown_function(function):
|
|
assert list_sessions() == [], 'session list is not empty when leaving "{}"'.format(function.__name__)
|
|
|
|
|
|
def make_description():
|
|
gcoption = ChoiceOption('name', 'GC name', ('ref', 'framework'), 'ref')
|
|
gcdummy = BoolOption('dummy', 'dummy', default=False)
|
|
objspaceoption = ChoiceOption('objspace', 'Object space',
|
|
('std', 'thunk'), 'std')
|
|
booloption = BoolOption('bool', 'Test boolean option', default=True)
|
|
intoption = IntOption('int', 'Test int option', default=0)
|
|
floatoption = FloatOption('float', 'Test float option', default=2.3)
|
|
stroption = StrOption('str', 'Test string option', default="abc")
|
|
boolop = BoolOption('boolop', 'Test boolean option op', default=True)
|
|
wantref_option = BoolOption('wantref', 'Test requires', default=False)
|
|
wantframework_option = BoolOption('wantframework', 'Test requires',
|
|
default=False)
|
|
gcgroup = OptionDescription('gc', '', [gcoption, gcdummy, floatoption])
|
|
descr = OptionDescription('tiramisu', '', [gcgroup, booloption, objspaceoption,
|
|
wantref_option, stroption,
|
|
wantframework_option,
|
|
intoption, boolop])
|
|
return descr
|
|
|
|
|
|
#____________________________________________________________
|
|
# change with __setattr__
|
|
@pytest.mark.asyncio
|
|
async def test_attribute_access(config_type):
|
|
"Once set, option values can't be changed again by attribute access"
|
|
s = StrOption("string", "", default="string")
|
|
descr = OptionDescription("options", "", [s])
|
|
cfg = await Config(descr)
|
|
cfg = await get_config(cfg, config_type)
|
|
# let's try to change it again
|
|
await cfg.option('string').value.set('foo')
|
|
assert await cfg.option('string').value.get() == 'foo'
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_mod_read_only_write():
|
|
"default with multi is a list"
|
|
s = StrOption("string", "", default=[], default_multi="string", multi=True)
|
|
descr = OptionDescription("options", "", [s])
|
|
config = await Config(descr)
|
|
config2 = await Config(descr)
|
|
assert await config.property.getdefault() == {'cache', 'validator', 'warnings'}
|
|
assert await config.property.getdefault('read_only', 'append') == {'frozen',
|
|
'disabled',
|
|
'validator',
|
|
'everything_frozen',
|
|
'mandatory',
|
|
'empty',
|
|
'force_store_value'}
|
|
assert await config.property.getdefault('read_only', 'remove') == {'permissive',
|
|
'hidden'}
|
|
assert await config.property.getdefault('read_write', 'append') == {'frozen',
|
|
'disabled',
|
|
'validator',
|
|
'hidden',
|
|
'force_store_value'}
|
|
assert await config.property.getdefault('read_write', 'remove') == {'permissive',
|
|
'everything_frozen',
|
|
'mandatory',
|
|
'empty'}
|
|
#
|
|
await config.property.setdefault(frozenset(['cache']))
|
|
await config.property.setdefault(type='read_only', when='append', properties=frozenset(['disabled']))
|
|
await config.property.setdefault(type='read_only', when='remove', properties=frozenset(['hidden']))
|
|
await config.property.setdefault(type='read_write', when='append', properties=frozenset(['disabled', 'hidden']))
|
|
await config.property.setdefault(type='read_write', when='remove', properties=frozenset([]))
|
|
with pytest.raises(ValueError):
|
|
await config.property.setdefault(type='unknown', when='append', properties=frozenset(['disabled']))
|
|
with pytest.raises(ValueError):
|
|
await config.property.setdefault(type='read_only', when='unknown', properties=frozenset(['disabled']))
|
|
with pytest.raises(TypeError):
|
|
await config.property.setdefault(type='read_only', when='append', properties=['disabled'])
|
|
|
|
assert await config.property.getdefault() == {'cache'}
|
|
assert await config.property.getdefault('read_only', 'append') == {'disabled'}
|
|
assert await config.property.getdefault('read_only', 'remove') == {'hidden'}
|
|
assert await config.property.getdefault('read_write', 'append') == {'disabled',
|
|
'hidden'}
|
|
assert await config.property.getdefault('read_write', 'remove') == set([])
|
|
#
|
|
await config.property.read_only()
|
|
assert await config.property.get() == {'cache', 'disabled'}
|
|
await config.property.read_write()
|
|
assert await config.property.get() == {'cache', 'disabled', 'hidden'}
|
|
await config.property.read_only()
|
|
assert await config.property.get() == {'cache', 'disabled'}
|
|
#
|
|
assert await config2.property.getdefault() == {'cache', 'validator', 'warnings'}
|
|
assert await config2.property.getdefault('read_only', 'append') == {'frozen',
|
|
'disabled',
|
|
'validator',
|
|
'everything_frozen',
|
|
'mandatory',
|
|
'empty',
|
|
'force_store_value'}
|
|
assert await config2.property.getdefault('read_only', 'remove') == {'permissive',
|
|
'hidden'}
|
|
assert await config2.property.getdefault('read_write', 'append') == {'frozen',
|
|
'disabled',
|
|
'validator',
|
|
'hidden',
|
|
'force_store_value'}
|
|
assert await config2.property.getdefault('read_write', 'remove') == {'permissive',
|
|
'everything_frozen',
|
|
'mandatory',
|
|
'empty'}
|
|
with pytest.raises(ValueError):
|
|
await config2.property.getdefault('unknown', 'remove')
|
|
with pytest.raises(ValueError):
|
|
await config2.property.getdefault('read_write', 'unknown')
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_setitem(config_type):
|
|
s = StrOption("string", "", default=["string", "sdfsdf"], default_multi="prout", multi=True)
|
|
descr = OptionDescription("options", "", [s])
|
|
cfg = await Config(descr)
|
|
cfg = await get_config(cfg, config_type)
|
|
await cfg.option('string').value.set([undefined, 'foo'])
|
|
assert await cfg.option('string').value.get() == ['string', 'foo']
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_reset(config_type):
|
|
"if value is None, resets to default owner"
|
|
s = StrOption("string", "", default="string")
|
|
descr = OptionDescription("options", "", [s])
|
|
cfg = await Config(descr)
|
|
cfg = await get_config(cfg, config_type)
|
|
await cfg.option('string').value.set('foo')
|
|
assert await cfg.option('string').value.get() == "foo"
|
|
assert await cfg.option('string').owner.get() ==owners.user
|
|
await cfg.option('string').value.reset()
|
|
assert await cfg.option('string').value.get() == 'string'
|
|
assert await cfg.option('string').owner.get() ==owners.default
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_reset_with_multi(config_type):
|
|
s = StrOption("string", "", default=["string"], default_multi="string", multi=True)
|
|
descr = OptionDescription("options", "", [s])
|
|
cfg = await Config(descr)
|
|
cfg = await get_config(cfg, config_type)
|
|
# await cfg.option('string').value.set([])
|
|
await cfg.option('string').value.reset()
|
|
assert await cfg.option('string').value.get() == ["string"]
|
|
assert await cfg.option('string').owner.get() =='default'
|
|
await cfg.option('string').value.set(["eggs", "spam", "foo"])
|
|
assert await cfg.option('string').owner.get() =='user'
|
|
await cfg.option('string').value.set([])
|
|
await cfg.option('string').value.reset()
|
|
# assert await cfg.option('string').value.get() == ["string"]
|
|
assert await cfg.option('string').owner.get() =='default'
|
|
with pytest.raises(ValueError):
|
|
await cfg.option('string').value.set(None)
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_property_get_unique_empty():
|
|
s = StrOption("string", "", default=["string"], default_multi="string", multi=True)
|
|
s2 = StrOption("string2", "", default=["string"], default_multi="string", multi=True, properties=('notunique',))
|
|
s3 = StrOption("string3", "", default=["string"], default_multi="string", multi=True, properties=('notempty',))
|
|
s4 = StrOption("string4", "", default=["string"], default_multi="string", multi=True, properties=('notunique', 'notempty'))
|
|
descr = OptionDescription("options", "", [s, s2, s3, s4])
|
|
cfg = await Config(descr)
|
|
await cfg.property.read_write()
|
|
assert await cfg.option('string').property.get() == {'empty', 'unique'}
|
|
assert await cfg.option('string2').property.get() == {'empty'}
|
|
assert await cfg.option('string3').property.get() == {'unique'}
|
|
assert await cfg.option('string4').property.get() == set()
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_property_only_raises():
|
|
s = StrOption("string", "", default=["string"], default_multi="string", multi=True)
|
|
intoption = IntOption('int', 'Test int option', default=0)
|
|
hidden_property = Calculation(calc_value,
|
|
Params(ParamValue('hidden'),
|
|
kwargs={'condition': ParamOption(intoption),
|
|
'expected': ParamValue(1)}))
|
|
stroption = StrOption('str', 'Test string option', default=["abc"], default_multi="abc", properties=(hidden_property,), multi=True)
|
|
descr = OptionDescription("options", "", [s, intoption, stroption])
|
|
cfg = await Config(descr)
|
|
await cfg.property.read_write()
|
|
assert await cfg.option('str').property.get() == {'empty', 'unique'}
|
|
assert await cfg.option('str').property.get(only_raises=True) == set()
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_default_with_multi():
|
|
"default with multi is a list"
|
|
s = StrOption("string", "", default=[], default_multi="string", multi=True)
|
|
descr = OptionDescription("options", "", [s])
|
|
cfg = await Config(descr)
|
|
assert await cfg.option('string').value.get() == []
|
|
s = StrOption("string", "", default=None, default_multi="string", multi=True)
|
|
descr = OptionDescription("options", "", [s])
|
|
cfg = await Config(descr)
|
|
assert await cfg.option('string').value.get() == []
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_idontexist():
|
|
descr = make_description()
|
|
cfg = await Config(descr)
|
|
await cfg.value.dict()
|
|
with pytest.raises(AttributeError):
|
|
await cfg.option('idontexist').value.get()
|
|
|
|
|
|
# ____________________________________________________________
|
|
@pytest.mark.asyncio
|
|
async def test_attribute_access_with_multi(config_type):
|
|
s = StrOption("string", "", default=["string"], default_multi="string", multi=True)
|
|
descr = OptionDescription("options", "", [s])
|
|
cfg = await Config(descr)
|
|
cfg = await get_config(cfg, config_type)
|
|
await cfg.option('string').value.set(["foo", "bar"])
|
|
assert await cfg.option('string').value.get() == ["foo", "bar"]
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_item_access_with_multi(config_type):
|
|
s = StrOption("string", "", default=["string"], multi=True)
|
|
descr = OptionDescription("options", "", [s])
|
|
cfg = await Config(descr)
|
|
cfg = await get_config(cfg, config_type)
|
|
await cfg.option('string').value.set(["foo", "bar"])
|
|
assert await cfg.option('string').value.get() == ["foo", "bar"]
|
|
await cfg.option('string').value.set(["changetest", "bar"])
|
|
assert await cfg.option('string').value.get() == ["changetest", "bar"]
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_access_with_multi_default(config_type):
|
|
s = StrOption("string", "", default=["string"], multi=True)
|
|
descr = OptionDescription("options", "", [s])
|
|
cfg = await Config(descr)
|
|
cfg = await get_config(cfg, config_type)
|
|
assert await cfg.option('string').owner.get() =='default'
|
|
await cfg.option('string').value.set(["foo", "bar"])
|
|
assert await cfg.option('string').value.get() == ["foo", "bar"]
|
|
assert await cfg.option('string').owner.get() =='user'
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_multi_with_requires():
|
|
s = StrOption("string", "", default=["string"], default_multi="string", multi=True)
|
|
intoption = IntOption('int', 'Test int option', default=0)
|
|
hidden_property = Calculation(calc_value,
|
|
Params(ParamValue('hidden'),
|
|
kwargs={'condition': ParamOption(intoption),
|
|
'expected': ParamValue(1)}))
|
|
stroption = StrOption('str', 'Test string option', default=["abc"], default_multi="abc", properties=(hidden_property,), multi=True)
|
|
descr = OptionDescription("options", "", [s, intoption, stroption])
|
|
cfg = await Config(descr)
|
|
await cfg.property.read_write()
|
|
assert not 'hidden' in await cfg.option('str').property.get()
|
|
await cfg.option('int').value.set(1)
|
|
with pytest.raises(PropertiesOptionError):
|
|
await cfg.option('str').value.set(['a', 'b'])
|
|
assert 'hidden' in await cfg.forcepermissive.option('str').property.get()
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_requires_with_inverted():
|
|
s = StrOption("string", "", default=["string"], multi=True)
|
|
intoption = IntOption('int', 'Test int option', default=0)
|
|
hide_property = Calculation(calc_value,
|
|
Params(ParamValue('hide'),
|
|
kwargs={'condition': ParamOption(intoption),
|
|
'expected': ParamValue(1),
|
|
'reverse_condition': ParamValue(True)}))
|
|
stroption = StrOption('str', 'Test string option', default=["abc"], default_multi="abc", properties=(hide_property,), multi=True)
|
|
descr = OptionDescription("options", "", [s, intoption, stroption])
|
|
cfg = await Config(descr)
|
|
assert not 'hidden' in await cfg.option('str').property.get()
|
|
assert 'hide' in await cfg.option('str').property.get()
|
|
await cfg.option('int').value.set(1)
|
|
assert not 'hidden' in await cfg.option('str').property.get()
|
|
assert not 'hide' in await cfg.option('str').property.get()
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_multi_with_requires_in_another_group():
|
|
s = StrOption("string", "", default=["string"], multi=True)
|
|
intoption = IntOption('int', 'Test int option', default=0)
|
|
hidden_property = Calculation(calc_value,
|
|
Params(ParamValue('hidden'),
|
|
kwargs={'condition': ParamOption(intoption),
|
|
'expected': ParamValue(1)}))
|
|
stroption = StrOption('str', 'Test string option', default=["abc"], properties=(hidden_property,), multi=True)
|
|
descr = OptionDescription("opt", "", [stroption])
|
|
descr2 = OptionDescription("opt2", "", [intoption, s, descr])
|
|
cfg = await Config(descr2)
|
|
await cfg.property.read_write()
|
|
assert not 'hidden' in await cfg.option('opt.str').property.get()
|
|
await cfg.option('int').value.set(1)
|
|
with pytest.raises(PropertiesOptionError):
|
|
await cfg.option('opt.str').value.set(['a', 'b'])
|
|
assert 'hidden' in await cfg.forcepermissive.option('opt.str').property.get()
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_multi_with_requires_in_another_group_inverse():
|
|
s = StrOption("string", "", default=["string"], multi=True)
|
|
intoption = IntOption('int', 'Test int option', default=0)
|
|
hidden_property = Calculation(calc_value,
|
|
Params(ParamValue('hidden'),
|
|
kwargs={'condition': ParamOption(intoption),
|
|
'expected': ParamValue(1)}))
|
|
# requires=[{'option': intoption, 'expected': 1, 'action': 'hidden'}], multi=True)
|
|
stroption = StrOption('str', 'Test string option', default=["abc"], properties=(hidden_property,), multi=True)
|
|
descr = OptionDescription("opt", "", [stroption])
|
|
descr2 = OptionDescription("opt2", "", [intoption, s, descr])
|
|
cfg = await Config(descr2)
|
|
await cfg.property.read_write()
|
|
assert not 'hidden' in await cfg.option('opt.str').property.get()
|
|
await cfg.option('int').value.set(1)
|
|
with pytest.raises(PropertiesOptionError):
|
|
await cfg.option('opt.str').value.set(['a', 'b'])
|
|
assert 'hidden' in await cfg.forcepermissive.option('opt.str').property.get()
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_apply_requires_from_config():
|
|
s = StrOption("string", "", default=["string"], multi=True)
|
|
intoption = IntOption('int', 'Test int option', default=0)
|
|
hidden_property = Calculation(calc_value,
|
|
Params(ParamValue('hidden'),
|
|
kwargs={'condition': ParamOption(intoption),
|
|
'expected': ParamValue(1)}))
|
|
stroption = StrOption('str', 'Test string option', default=["abc"], properties=(hidden_property,), multi=True)
|
|
descr = OptionDescription("opt", "", [stroption])
|
|
descr2 = OptionDescription("opt2", "", [intoption, s, descr])
|
|
cfg = await Config(descr2)
|
|
await cfg.property.read_write()
|
|
assert not 'hidden' in await cfg.option('opt.str').property.get()
|
|
await cfg.option('int').value.set(1)
|
|
with pytest.raises(PropertiesOptionError):
|
|
await cfg.option('opt.str').value.get()
|
|
assert 'hidden' in await cfg.forcepermissive.option('opt.str').property.get()
|
|
assert 'hidden' not in await cfg.forcepermissive.option('opt.str').option.properties()
|
|
assert 'hidden' not in await cfg.forcepermissive.option('opt.str').option.properties(only_raises=True)
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_apply_requires_with_disabled():
|
|
s = StrOption("string", "", default=["string"], multi=True)
|
|
intoption = IntOption('int', 'Test int option', default=0)
|
|
disabled_property = Calculation(calc_value,
|
|
Params(ParamValue('disabled'),
|
|
kwargs={'condition': ParamOption(intoption),
|
|
'expected': ParamValue(1)}))
|
|
stroption = StrOption('str', 'Test string option', default=["abc"], properties=(disabled_property,), multi=True)
|
|
descr = OptionDescription("opt", "", [stroption])
|
|
descr2 = OptionDescription("opt2", "", [intoption, s, descr])
|
|
cfg = await Config(descr2)
|
|
await cfg.property.read_write()
|
|
assert not 'disabled' in await cfg.option('opt.str').property.get()
|
|
await cfg.option('int').value.set(1)
|
|
with pytest.raises(PropertiesOptionError):
|
|
await cfg.option('opt.str').value.get()
|
|
assert 'disabled' not in await cfg.unrestraint.option('opt.str').option.properties()
|
|
assert 'disabled' not in await cfg.unrestraint.option('opt.str').option.properties(only_raises=True)
|
|
assert 'disabled' in await cfg.unrestraint.option('opt.str').property.get()
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_multi_with_requires_with_disabled_in_another_group():
|
|
s = StrOption("string", "", default=["string"], multi=True)
|
|
intoption = IntOption('int', 'Test int option', default=0)
|
|
disabled_property = Calculation(calc_value,
|
|
Params(ParamValue('disabled'),
|
|
kwargs={'condition': ParamOption(intoption),
|
|
'expected': ParamValue(1)}))
|
|
stroption = StrOption('str', 'Test string option', default=["abc"], properties=(disabled_property,), multi=True)
|
|
descr = OptionDescription("opt", "", [stroption])
|
|
descr2 = OptionDescription("opt2", "", [intoption, s, descr])
|
|
cfg = await Config(descr2)
|
|
await cfg.property.read_write()
|
|
assert not 'disabled' in await cfg.option('opt.str').property.get()
|
|
await cfg.option('int').value.set(1)
|
|
with pytest.raises(PropertiesOptionError):
|
|
await cfg.option('opt.str').value.set(['a', 'b'])
|
|
assert 'disabled' in await cfg.unrestraint.option('opt.str').property.get()
|
|
#
|
|
#
|
|
#@pytest.mark.asyncio
|
|
#async def test_multi_with_requires_that_is_multi():
|
|
# b = IntOption('int', 'Test int option', default=[0], multi=True)
|
|
# hidden_property = Calculation(calc_value,
|
|
# Params(ParamValue('hidden'),
|
|
# kwargs={'condition': ParamOption(b),
|
|
# 'expected': ParamValue(1)}))
|
|
# c = StrOption('str', 'Test string option', default=['abc'], properties=(hidden_property,), multi=True)
|
|
# descr = OptionDescription("opt", "", [b, c])
|
|
# descr
|
|
# # FIXME: ValueError: requirement mal formés pour l'option "int" ne doit pas être une valeur multiple pour "str"
|
|
# with pytest.raises(ValueError):
|
|
# Config(descr)")
|
|
#
|
|
#
|
|
#@pytest.mark.asyncio
|
|
#async def test_multi_with_requires_that_is_multi_inverse():
|
|
# b = IntOption('int', 'Test int option', default=[0], multi=True)
|
|
# c = StrOption('str', 'Test string option', default=['abc'], requires=[{'option': b, 'expected': 0, 'action': 'hidden', 'inverse': True}], multi=True)
|
|
# descr = OptionDescription("opt", "", [b, c])
|
|
# descr
|
|
# Config(descr)
|
|
# # FIXME: ValueError: requirement mal formés pour l'option "int" ne doit pas être une valeur multiple pour "str"
|
|
# with pytest.raises(ValueError):
|
|
# Config(descr)")
|
|
#
|
|
#
|
|
#@pytest.mark.asyncio
|
|
#async def test_multi_with_requires_that_is_leadership():
|
|
# b = IntOption('int', 'Test int option', default=[0], multi=True)
|
|
# c = StrOption('str', 'Test string option', requires=[{'option': b, 'expected': 1, 'action': 'hidden'}], multi=True)
|
|
# descr = Leadership("int", "", [b, c])
|
|
# od = OptionDescription('root', '', [descr])
|
|
# Config(od)
|
|
#
|
|
#
|
|
#@pytest.mark.asyncio
|
|
#async def test_multi_with_requires_that_is_leadership_leader():
|
|
# b = IntOption('int', 'Test int option', multi=True)
|
|
# c = StrOption('str', 'Test string option', requires=[{'option': b, 'expected': 1, 'action': 'hidden'}], multi=True)
|
|
# with pytest.raises(ValueError):
|
|
# Leadership('str', '', [c, b])")
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_multi_with_requires_that_is_leadership_follower():
|
|
b = IntOption('int', 'Test int option', default=[0], multi=True)
|
|
c = StrOption('str', 'Test string option', multi=True)
|
|
hidden_property = Calculation(calc_value,
|
|
Params(ParamValue('hidden'),
|
|
kwargs={'condition': ParamOption(c),
|
|
'index': ParamIndex(),
|
|
'expected': ParamValue('1')}))
|
|
d = StrOption('str1', 'Test string option', properties=(hidden_property,), multi=True)
|
|
descr = Leadership("int", "", [b, c, d])
|
|
descr2 = OptionDescription('od', '', [descr])
|
|
cfg = await Config(descr2)
|
|
await cfg.property.read_write()
|
|
assert await cfg.option('int.int').value.get() == [0]
|
|
assert await cfg.option('int.str', 0).value.get() == None
|
|
assert await cfg.option('int.str1', 0).value.get() == None
|
|
await cfg.option('int.int').value.set([0, 1])
|
|
assert await cfg.option('int.int').value.get() == [0, 1]
|
|
assert await cfg.option('int.str', 0).value.get() == None
|
|
assert await cfg.option('int.str', 1).value.get() == None
|
|
assert await cfg.option('int.str1', 0).value.get() == None
|
|
assert await cfg.option('int.str1', 1).value.get() == None
|
|
await cfg.option('int.str', 1).value.set('1')
|
|
await cfg.property.read_only()
|
|
assert await cfg.option('int.str1', 0).value.get() == None
|
|
assert await cfg.option('int.str1', 1).value.get() == None
|
|
await cfg.property.read_write()
|
|
assert await cfg.option('int.str1', 0).value.get() == None
|
|
with pytest.raises(PropertiesOptionError):
|
|
await cfg.option('int.str1', 1).value.get()
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_multi_with_requires_that_is_leadership_follower_inverse():
|
|
b = IntOption('int', 'Test int option', default=[0], multi=True)
|
|
c = StrOption('str', 'Test string option', multi=True)
|
|
hidden_property = Calculation(calc_value,
|
|
Params(ParamValue('hidden'),
|
|
kwargs={'condition': ParamOption(c),
|
|
'index': ParamIndex(),
|
|
'reverse_condition': ParamValue(True),
|
|
'expected': ParamValue(None)}))
|
|
d = StrOption('str1', 'Test string option', properties=(hidden_property,), multi=True)
|
|
descr = Leadership("int", "", [b, c, d])
|
|
descr2 = OptionDescription('od', '', [descr])
|
|
cfg = await Config(descr2)
|
|
await cfg.property.read_write()
|
|
assert await cfg.option('int.int').value.get() == [0]
|
|
assert await cfg.option('int.str', 0).value.get() is None
|
|
assert await cfg.option('int.str1', 0).value.get() is None
|
|
await cfg.option('int.int').value.set([0, 1])
|
|
assert await cfg.option('int.int').value.get() == [0, 1]
|
|
assert await cfg.option('int.str', 0).value.get() is None
|
|
assert await cfg.option('int.str', 1).value.get() is None
|
|
assert await cfg.option('int.str1', 0).value.get() is None
|
|
assert await cfg.option('int.str1', 1).value.get() is None
|
|
await cfg.option('int.str', 1).value.set('1')
|
|
await cfg.property.read_only()
|
|
assert await cfg.option('int.str1', 0).value.get() is None
|
|
assert await cfg.option('int.str1', 1).value.get() is None
|
|
await cfg.property.read_write()
|
|
assert await cfg.option('int.str1', 0).value.get() is None
|
|
with pytest.raises(PropertiesOptionError):
|
|
await cfg.option('int.str1', 1).value.get()
|
|
|
|
|
|
#@pytest.mark.asyncio
|
|
#async def test_multi_with_requires_that_is_not_same_leadership():
|
|
# b = IntOption('int', 'Test int option', default=[0], multi=True)
|
|
# hidden_property = Calculation(calc_value,
|
|
# Params(ParamValue('hidden'),
|
|
# kwargs={'condition': ParamOption(b),
|
|
# 'index': ParamIndex(),
|
|
# 'expected': ParamValue(1)}))
|
|
# c = StrOption('str', 'Test string option', properties=(hidden_property,), multi=True)
|
|
# #c = StrOption('str', 'Test string option', requires=[{'option': b, 'expected': 1, 'action': 'hidden'}], multi=True)
|
|
# descr1 = Leadership("int", "", [b, c])
|
|
# d = IntOption('int1', 'Test int option', default=[0], multi=True)
|
|
# e = StrOption('str', 'Test string option', requires=[{'option': b, 'expected': 1, 'action': 'hidden'}], multi=True)
|
|
# descr2 = Leadership("int1", "", [d, e])
|
|
# descr3 = OptionDescription('val', '', [descr1, descr2])
|
|
# descr3
|
|
# with pytest.raises(ValueError):
|
|
# Config(descr3)")
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_multi_with_bool():
|
|
s = BoolOption("bool", "", default=[False], multi=True)
|
|
descr = OptionDescription("options", "", [s])
|
|
cfg = await Config(descr)
|
|
await cfg.option('bool').value.set([True, False])
|
|
assert await cfg.option('bool').value.get() == [True, False]
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_choice_access_with_multi():
|
|
ch = ChoiceOption("t1", "", ("a", "b"), default=["a"], multi=True, properties=('notunique',))
|
|
descr = OptionDescription("options", "", [ch])
|
|
cfg = await Config(descr)
|
|
await cfg.option('t1').value.set(["a", "b", "a", "b"])
|
|
assert await cfg.option('t1').value.get() == ["a", "b", "a", "b"]
|
|
|
|
|
|
#____________________________________________________________
|
|
@pytest.mark.asyncio
|
|
async def test_accepts_multiple_changes_from_option():
|
|
s = StrOption("string", "", default="string")
|
|
descr = OptionDescription("options", "", [s])
|
|
cfg = await Config(descr)
|
|
await cfg.option('string').value.set("egg")
|
|
assert await cfg.option('string').option.default() == "string"
|
|
assert await cfg.option('string').value.get() == "egg"
|
|
await cfg.option('string').value.set('blah')
|
|
assert await cfg.option('string').option.default() == "string"
|
|
assert await cfg.option('string').value.get() == "blah"
|
|
await cfg.option('string').value.set('bol')
|
|
assert await cfg.option('string').value.get() == 'bol'
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_allow_multiple_changes_from_config():
|
|
"""
|
|
a `setoption` from the config object is much like the attribute access,
|
|
except the fact that value owner can bet set
|
|
"""
|
|
s = StrOption("string", "", default="string")
|
|
s2 = StrOption("string2", "", default="string")
|
|
suboption = OptionDescription("bip", "", [s2])
|
|
descr = OptionDescription("options", "", [s, suboption])
|
|
cfg = await Config(descr)
|
|
await cfg.option('string').value.set("oh")
|
|
assert await cfg.option('string').value.get() == "oh"
|
|
await cfg.option('string').value.set("blah")
|
|
assert await cfg.option('string').value.get() == "blah"
|
|
|
|
|
|
# ____________________________________________________________
|
|
# accessing a value by the get method
|
|
@pytest.mark.asyncio
|
|
async def test_access_by_get():
|
|
descr = make_description()
|
|
cfg = await Config(descr)
|
|
with pytest.raises(AttributeError):
|
|
list(await cfg.option.find('idontexist'))
|
|
ret = await cfg.option.find('wantref', first=True)
|
|
assert await ret.value.get() is False
|
|
ret = await cfg.option.find('dummy', first=True)
|
|
assert await ret.value.get() is False
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_access_by_get_whith_hide():
|
|
b1 = BoolOption("b1", "", properties=(('hidden'),))
|
|
descr = OptionDescription("opt", "",
|
|
[OptionDescription("sub", "",
|
|
[b1, ChoiceOption("c1", "", ('a', 'b', 'c'), 'a'),
|
|
BoolOption("d1", "")]),
|
|
BoolOption("b2", ""),
|
|
BoolOption("d1", "")])
|
|
cfg = await Config(descr)
|
|
await cfg.property.read_write()
|
|
with pytest.raises(AttributeError):
|
|
ret = await cfg.option.find('b1')
|
|
await ret.value.get()
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_append_properties():
|
|
descr = make_description()
|
|
cfg = await Config(descr)
|
|
assert await cfg.option('gc.dummy').property.get() == set()
|
|
await cfg.option('gc.dummy').property.add('test')
|
|
assert await cfg.option('gc.dummy').property.get() == {'test'}
|
|
with pytest.raises(ConfigError):
|
|
await cfg.option('gc.dummy').property.add('force_store_value')
|
|
assert await cfg.option('gc.dummy').property.get() == {'test'}
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_reset_properties():
|
|
descr = make_description()
|
|
cfg = await Config(descr)
|
|
assert await cfg.option('gc.dummy').property.get() == set()
|
|
await cfg.option('gc.dummy').property.add('frozen')
|
|
assert await cfg.option('gc.dummy').property.get() == {'frozen'}
|
|
await cfg.option('gc.dummy').property.reset()
|
|
assert await cfg.option('gc.dummy').property.get() == set()
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_properties_cached():
|
|
b1 = BoolOption("b1", "", properties=('test',))
|
|
descr = OptionDescription("opt", "", [OptionDescription("sub", "", [b1])])
|
|
cfg = await Config(descr)
|
|
await cfg.property.read_write()
|
|
assert await cfg.option('sub.b1').property.get() == {'test'}
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_append_properties_force_store_value():
|
|
gcdummy = BoolOption('dummy', 'dummy', default=False, properties=('force_store_value',))
|
|
gcgroup = OptionDescription('gc', '', [gcdummy])
|
|
descr = OptionDescription('tiramisu', '', [gcgroup])
|
|
cfg = await Config(descr)
|
|
assert await cfg.option('gc.dummy').property.get() == {'force_store_value'}
|
|
await cfg.option('gc.dummy').property.add('test')
|
|
assert await cfg.option('gc.dummy').property.get() == {'force_store_value', 'test'}
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_reset_properties_force_store_value():
|
|
gcdummy = BoolOption('dummy', 'dummy', default=False, properties=('force_store_value',))
|
|
gcgroup = OptionDescription('gc', '', [gcdummy])
|
|
descr = OptionDescription('tiramisu', '', [gcgroup])
|
|
cfg = await Config(descr)
|
|
assert await cfg.property.exportation() == {}
|
|
await cfg.property.add('frozen')
|
|
assert await cfg.property.exportation() == \
|
|
{None: {None: set(('frozen', 'cache', 'validator', 'warnings'))}}
|
|
await cfg.property.reset()
|
|
if environ.get('TIRAMISU_STORAGE') == 'sqlite3':
|
|
assert await cfg.property.exportation() == {}
|
|
else:
|
|
assert await cfg.property.exportation() == {None: {}}
|
|
await cfg.option('gc.dummy').property.add('test')
|
|
if environ.get('TIRAMISU_STORAGE') == 'sqlite3':
|
|
assert await cfg.property.exportation() == {'gc.dummy': {None: set(('test', 'force_store_value'))}}
|
|
else:
|
|
assert await cfg.property.exportation() == {None: {}, 'gc.dummy': {None: set(('test', 'force_store_value'))}}
|
|
await cfg.property.reset()
|
|
if environ.get('TIRAMISU_STORAGE') == 'sqlite3':
|
|
assert await cfg.property.exportation() == {'gc.dummy': {None: set(('test', 'force_store_value'))}}
|
|
else:
|
|
assert await cfg.property.exportation() == {None: {}, 'gc.dummy': {None: set(('test', 'force_store_value'))}}
|
|
await cfg.property.add('frozen')
|
|
assert await cfg.property.exportation() == \
|
|
{None: {None: set(('frozen', 'validator', 'cache', 'warnings'))},
|
|
'gc.dummy': {None: set(('test', 'force_store_value'))}}
|
|
await cfg.property.add('frozen')
|
|
assert await cfg.property.exportation() == \
|
|
{None: {None: set(('frozen', 'validator', 'cache', 'warnings'))},
|
|
'gc.dummy': {None: set(('test', 'force_store_value'))}}
|
|
await cfg.option('gc.dummy').property.add('test')
|
|
assert await cfg.property.exportation() == \
|
|
{None: {None: set(('frozen', 'validator', 'cache', 'warnings'))},
|
|
'gc.dummy': {None: set(('test', 'force_store_value'))}}
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_importation_force_store_value():
|
|
gcdummy = BoolOption('dummy', 'dummy', default=False,
|
|
properties=('force_store_value',))
|
|
gcgroup = OptionDescription('gc', '', [gcdummy])
|
|
descr = OptionDescription('tiramisu', '', [gcgroup])
|
|
config1 = await Config(descr)
|
|
assert await config1.value.exportation() == [[], [], [], []]
|
|
await config1.property.add('frozen')
|
|
assert await config1.value.exportation() == [[], [], [], []]
|
|
await config1.property.add('force_store_value')
|
|
assert await config1.value.exportation() == [['gc.dummy'], [None], [False], ['forced']]
|
|
exportation = await config1.property.exportation()
|
|
config2 = await Config(descr)
|
|
assert await config2.value.exportation() == [[], [], [], []]
|
|
await config2.property.importation(exportation)
|
|
assert await config2.value.exportation() == [['gc.dummy'], [None], [False], ['forced']]
|
|
await config2.property.importation(exportation)
|
|
assert await config2.value.exportation() == [['gc.dummy'], [None], [False], ['forced']]
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_set_modified_value():
|
|
gcdummy = BoolOption('dummy', 'dummy', default=False, properties=('force_store_value',))
|
|
gcgroup = OptionDescription('gc', '', [gcdummy])
|
|
descr = OptionDescription('tiramisu', '', [gcgroup])
|
|
cfg = await Config(descr)
|
|
assert await cfg.property.exportation() == {}
|
|
await cfg.property.importation({None: {None: set(('frozen', 'cache', 'validator', 'warnings'))}})
|
|
assert await cfg.property.exportation() == \
|
|
{None: {None: set(('frozen', 'cache', 'validator', 'warnings'))}}
|
|
|
|
|
|
@pytest.mark.asyncio
|
|
async def test_pprint():
|
|
msg_error = _("cannot access to {0} \"{1}\" because has {2} {3}")
|
|
msg_is_not = _('the value of "{0}" is not {1}')
|
|
msg_is = _('the value of "{0}" is {1}')
|
|
properties = _('properties')
|
|
prop = _('property')
|
|
|
|
s = StrOption("string", "", default=["string"], default_multi="string", multi=True, properties=('hidden', 'disabled'))
|
|
s2 = StrOption("string2", "", default="string")
|
|
s3 = StrOption("string3", "", default=["string"], default_multi="string", multi=True, properties=('hidden',))
|
|
intoption = IntOption('int', 'Test int option', default=0)
|
|
hidden_property = Calculation(calc_value,
|
|
Params(ParamValue('hidden'),
|
|
kwargs={'condition': ParamOption(intoption, todict=True),
|
|
'expected_0': ParamValue(2),
|
|
'expected_1': ParamValue(3),
|
|
'expected_2': ParamValue(4),
|
|
'reverse_condition': ParamValue(True)}),
|
|
calc_value_property_help)
|
|
disabled_property = Calculation(calc_value,
|
|
Params(ParamValue('disabled'),
|
|
kwargs={'condition_0': ParamOption(intoption, todict=True),
|
|
'expected_0': ParamValue(1),
|
|
'condition_1': ParamOption(s2, todict=True),
|
|
'expected_1': ParamValue('string')}),
|
|
calc_value_property_help)
|
|
stroption = StrOption('str', 'Test string option', default="abc", properties=(hidden_property, disabled_property))
|
|
# requires=[{'option': intoption, 'expected': 2, 'action': 'hidden', 'inverse': True},
|
|
# {'option': intoption, 'expected': 3, 'action': 'hidden', 'inverse': True},
|
|
# {'option': intoption, 'expected': 4, 'action': 'hidden', 'inverse': True},
|
|
# {'option': intoption, 'expected': 1, 'action': 'disabled'},
|
|
# {'option': s2, 'expected': 'string', 'action': 'disabled'}])
|
|
|
|
val2 = StrOption('val2', "")
|
|
hidden_property = Calculation(calc_value,
|
|
Params(ParamValue('hidden'),
|
|
kwargs={'condition': ParamOption(intoption, todict=True),
|
|
'expected': ParamValue(1)}),
|
|
calc_value_property_help)
|
|
descr2 = OptionDescription("options", "", [val2], properties=(hidden_property,))
|
|
#descr2 = OptionDescription("options", "", [val2], requires=[{'option': intoption, 'expected': 1, 'action': 'hidden'}])
|
|
|
|
hidden_property = Calculation(calc_value,
|
|
Params(ParamValue('hidden'),
|
|
kwargs={'condition': ParamOption(stroption, todict=True),
|
|
'expected': ParamValue('2'),
|
|
'reverse_condition': ParamValue(True)}),
|
|
calc_value_property_help)
|
|
val3 = StrOption('val3', "", properties=(hidden_property,))
|
|
#val3 = StrOption('val3', "", requires=[{'option': stroption, 'expected': '2', 'action': 'hidden', 'inverse': True}])
|
|
|
|
descr = OptionDescription("options", "", [s, s2, s3, intoption, stroption, descr2, val3])
|
|
cfg = await Config(descr)
|
|
await cfg.property.read_write()
|
|
await cfg.option('int').value.set(1)
|
|
err = None
|
|
try:
|
|
await cfg.option('str').value.get()
|
|
except PropertiesOptionError as error:
|
|
err = error
|
|
|
|
list_disabled = '"disabled" (' + display_list([msg_is.format('Test int option', '"1"'), msg_is.format('string2', '"string"')], add_quote=False) + ')'
|
|
list_hidden = '"hidden" (' + msg_is_not.format('Test int option', display_list([2, 3, 4], 'or', add_quote=True)) + ')'
|
|
# FIXME assert str(err) == _(msg_error.format('option', 'Test string option', properties, display_list([list_disabled, list_hidden], add_quote=False)))
|
|
del err
|
|
|
|
err = None
|
|
try:
|
|
await cfg.option('options.val2').value.get()
|
|
except PropertiesOptionError as error:
|
|
err = error
|
|
|
|
# FIXME assert str(err) == msg_error.format('optiondescription', 'options', prop, '"hidden" (' + msg_is.format('Test int option', '"1"') + ')')
|
|
|
|
#err = None
|
|
#try:
|
|
# await cfg.option('val3').value.get()
|
|
#except PropertiesOptionError as error:
|
|
# err = error
|
|
|
|
#msg_1 = msg_is.format('string2', 'string')
|
|
#msg_2 = msg_is.format('Test int option', 1)
|
|
#msg_3 = msg_is_not.format('Test int option', display_list([2, 3, 4], 'or', add_quote=True))
|
|
#list_hidden = '"hidden" (' + display_list([msg_2, msg_3, msg_1]) + ')'
|
|
|
|
#assert str(err) == msg_error.format('option', 'val3', prop, list_hidden)
|
|
|
|
err = None
|
|
try:
|
|
await cfg.option('string').value.get()
|
|
except Exception as error:
|
|
err = error
|
|
|
|
assert str(err) == msg_error.format('option', 'string', properties, display_list(['disabled', 'hidden'], add_quote=True))
|
|
del err
|
|
|
|
err = None
|
|
try:
|
|
await cfg.option('string3').value.get()
|
|
except Exception as error:
|
|
err = error
|
|
|
|
assert str(err) == msg_error.format('option', 'string3', prop, '"hidden"')
|
|
del err
|