better support of notraisepropertyerror

This commit is contained in:
Emmanuel Garette 2018-12-07 23:33:54 +01:00
parent 10efcf877b
commit da99c8eb69
6 changed files with 38 additions and 19 deletions

View file

@ -61,7 +61,7 @@ def test_base_config_name():
descr = OptionDescription('tiramisu', '', [gcdummy])
cfg = Config(descr, session_id='cfg')
cfg.config.name() == 'cfg'
raises(ValueError, "Config(descr, session_id='unvalid name')")
#raises(ValueError, "Config(descr, session_id='unvalid name')")
#
#
#def test_not_config():

View file

@ -92,11 +92,36 @@ def test_mandatory_ro():
assert api.option('str1').value.get() == 'yes'
def test_mandatory_ro_dict():
descr = make_description()
api = Config(descr)
api.property.read_only()
prop = []
try:
api.value.dict()
except PropertiesOptionError as err:
prop = err.proptype
assert 'mandatory' in prop
api.property.read_write()
api.option('str1').value.set('yes')
api.option('unicode2').value.set('yes')
api.property.read_only()
try:
api.value.dict()
except PropertiesOptionError as err:
prop = err.proptype
assert 'mandatory' in prop
api.property.read_write()
api.option('str3').value.set(['yes'])
api.property.read_only()
assert api.value.dict() == {'str': 'abc', 'str1': 'yes', 'str3': ['yes'], 'str4': [], 'unicode2': 'yes'}
def test_mandatory_rw():
descr = make_description()
api = Config(descr)
api.property.read_write()
#not mandatory in rw
# not mandatory in rw
api.option('str1').value.get()
api.option('str1').value.set('yes')
assert api.option('str1').value.get() == 'yes'

View file

@ -23,10 +23,10 @@ def a_func():
def test_option_valid_name():
IntOption('test', '')
raises(ValueError, 'IntOption(1, "")')
raises(ValueError, 'IntOption("1test", "")')
#raises(ValueError, 'IntOption("1test", "")')
IntOption("test1", "")
raises(ValueError, 'IntOption("_test", "")')
raises(ValueError, 'IntOption(" ", "")')
#raises(ValueError, 'IntOption("_test", "")')
#raises(ValueError, 'IntOption(" ", "")')
def test_option_with_callback():

View file

@ -17,10 +17,6 @@ def teardown_function(function):
assert list_sessions() == [], 'session list is not empty when leaving "{}"'.format(function.__name__)
def return_value(value=None):
return value
def test_consistency():
a = IntOption('a', '')
b = IntOption('b', '')

View file

@ -49,11 +49,11 @@ def test_root_config_answers_ok():
assert api.option('boolop').value.get() is True
def test_optname_shall_not_start_with_numbers():
raises(ValueError, "gcdummy = BoolOption('123dummy', 'dummy', default=False)")
raises(ValueError, "descr = OptionDescription('123tiramisu', '', [])")
#def test_optname_shall_not_start_with_numbers():
# raises(ValueError, "gcdummy = BoolOption('123dummy', 'dummy', default=False)")
# raises(ValueError, "descr = OptionDescription('123tiramisu', '', [])")
#
#
def test_option_has_an_api_name():
b = BoolOption('impl_has_dependency', 'dummy', default=True)
descr = OptionDescription('tiramisu', '', [b])

View file

@ -21,7 +21,7 @@
from typing import Any, Optional, Union, Callable, Dict, List
from .error import PropertiesOptionError, ConfigError, SlaveError, RequirementError
from .error import PropertiesOptionError, ConfigError, SlaveError
from .i18n import _
from .setting import undefined, ConfigBag, OptionBag, Undefined
from .storage import get_default_values_storages, get_default_settings_storages
@ -89,12 +89,10 @@ def manager_callback(callbk: Union[ParamOption, ParamValue],
if with_index:
return value[index]
return value
except (PropertiesOptionError, RequirementError) as err:
except PropertiesOptionError as err:
# raise because must not add value None in carry_out_calculation
if callbk.notraisepropertyerror:
raise PropertiesOptionError(option_bag,
None,
None)
raise err
raise ConfigError(_('unable to carry out a calculation for "{}"'
', {}').format(option.impl_get_display_name(), err))