From 4b41fd89fb967ed598c53ecad2f9c1ca30ba7949 Mon Sep 17 00:00:00 2001 From: Emmanuel Garette Date: Wed, 12 Apr 2023 11:42:27 +0200 Subject: [PATCH] calculation with options not in same dynoptiondescription --- tests/test_dyn_optiondescription.py | 45 +++++++++++++++++++++++++++++ tiramisu/autolib.py | 28 +++++++++++------- 2 files changed, 62 insertions(+), 11 deletions(-) diff --git a/tests/test_dyn_optiondescription.py b/tests/test_dyn_optiondescription.py index 656cdd6..fbe3273 100644 --- a/tests/test_dyn_optiondescription.py +++ b/tests/test_dyn_optiondescription.py @@ -881,6 +881,51 @@ async def test_requires_dyndescription_in_dyn(): assert not await list_sessions() +def calc_value_not_same(param, condition, expected, default, suffix): + if suffix == 'val1': + index = 0 + else: + index = 1 + return calc_value(param, condition=condition[index], expected=expected, default=default) + + +@pytest.mark.asyncio +async def test_requires_dyndescription_in_dyn_not_same(): + boolean = BoolOption('boolean', '', True) + disabled_property = Calculation(calc_value_not_same, + Params(ParamValue('disabled'), + kwargs={'condition': ParamOption(boolean, raisepropertyerror=True), + 'expected': ParamValue(False), + 'default': ParamValue(None), + 'suffix': ParamSuffix()})) + st = StrOption('st', '', properties=(disabled_property,)) + dod1 = DynOptionDescription('dod1', '', [boolean], suffixes=Calculation(return_list)) + dod2 = DynOptionDescription('dod2', '', [st], suffixes=Calculation(return_list)) + od = OptionDescription('od', '', [dod1, dod2]) + od2 = OptionDescription('od', '', [od]) + async with await Config(od2) as cfg: + await cfg.property.read_write() + + assert await cfg.option('od.dod2val1.stval1').value.get() is None + assert await cfg.option('od.dod2val2.stval2').value.get() is None + # + await cfg.option('od.dod1val1.booleanval1').value.set(False) + + props = [] + try: + await cfg.option('od.dod2val1.stval1').value.get() + except PropertiesOptionError as err: + props = err.proptype + assert props == frozenset(['disabled']) + props = [] + await cfg.option('od.dod2val2.stval2').value.get() + # + await cfg.option('od.dod1val1.booleanval1').value.set(True) + assert await cfg.option('od.dod2val1.stval1').value.get() is None + assert await cfg.option('od.dod2val2.stval2').value.get() is None + assert not await list_sessions() + + @pytest.mark.asyncio async def test_requires_dyndescription2(): boolean = BoolOption('boolean', '', True) diff --git a/tiramisu/autolib.py b/tiramisu/autolib.py index f8e3ac4..9cb5045 100644 --- a/tiramisu/autolib.py +++ b/tiramisu/autolib.py @@ -359,6 +359,7 @@ async def manager_callback(callbk: Param, callbk_option = callbk.option callbk_options = None if callbk_option.issubdyn(): + found = False if isinstance(callbk, ParamDynOption): subdyn = callbk.dynoptiondescription rootpath = subdyn.impl_getpath() + callbk.suffix @@ -366,7 +367,22 @@ async def manager_callback(callbk: Param, callbk_option = callbk_option.to_dynoption(rootpath, suffix, subdyn) - elif not option.impl_is_dynsymlinkoption(): + found = True + elif option.impl_is_dynsymlinkoption(): + rootpath = option.rootpath + call_path = callbk_option.impl_getpath() + if call_path.startswith(option.opt.impl_getpath().rsplit('.', 1)[0]): + # in same dynoption + if len(callbk_option.impl_getpath().split('.')) == len(rootpath.split('.')): + rootpath = rootpath.rsplit('.', 1)[0] + suffix = option.impl_getsuffix() + subdyn = callbk_option.getsubdyn() + callbk_option = callbk_option.to_dynoption(rootpath, + suffix, + subdyn, + ) + found = True + if not found: callbk_options = [] dynopt = callbk_option.getsubdyn() rootpath = dynopt.impl_getpath() @@ -378,16 +394,6 @@ async def manager_callback(callbk: Param, suffix, dynopt) callbk_options.append(doption) - else: - #FIXME in same dynamic option? - rootpath = option.rootpath - if len(callbk_option.impl_getpath().split('.')) == len(rootpath.split('.')): - rootpath = rootpath.rsplit('.', 1)[0] - suffix = option.impl_getsuffix() - subdyn = callbk_option.getsubdyn() - callbk_option = callbk_option.to_dynoption(rootpath, - suffix, - subdyn) if leadership_must_have_index and callbk_option.impl_is_follower() and index is None: raise Break() if config_bag is undefined: