7 Commits

7 changed files with 43 additions and 10 deletions

View File

14
tests/test_simple.py Normal file
View File

@ -0,0 +1,14 @@
from json import loads
from tiramisu_api import Config
from pytest import raises
def test_list_option():
filename = 'tests/data/boolean1.json'
with open(filename, 'r') as fh:
json = loads(fh.read())
#
config = Config(json)
opts = []
raises(AttributeError, "config.option('unknown').value.get()")
raises(AttributeError, "config.option('options.unknown').value.get()")

View File

@ -1,5 +1,5 @@
from .api import Config
__version__ = "0.1"
__version__ = "0.4"
__all__ = ('Config',)

View File

@ -75,6 +75,12 @@ class TiramisuOptionOption:
self.schema = schema
def doc(self):
description = self.description()
if not description:
return self.name()
return description
def description(self):
if self.issymlinkoption():
schema = self.config.get_schema(self.schema['opt_path'])
else:
@ -320,11 +326,11 @@ class TiramisuOptionValue(_Value):
def set(self, value):
type_ = self.schema['type']
leader_old_value = undefined
if self.config.is_hidden(self.path, self.index):
remote = self.config.form.get(self.path, {}).get('remote', False)
if not remote and self.config.is_hidden(self.path, self.index):
raise PropertiesOptionError(None, {'disabled'}, None, opt_type='option')
if self.config.isleader(self.path):
leader_old_value = self.config.get_value(self.path)
remote = self.config.form.get(self.path, {}).get('remote', False)
if self.index is None and self.schema.get('isMulti', False):
if not isinstance(value, list):
raise ValueError('value must be a list')
@ -568,7 +574,7 @@ class ContextOption(_Option):
schema: Dict) -> None:
self.config = config
self.schema = {'properties': schema}
self.index = None
self.index = None
def __call__(self,
path: str,
@ -591,7 +597,7 @@ class ContextOwner:
schema: Dict) -> None:
self.config = config
self.schema = {'properties': schema}
self.index = None
self.index = None
def get(self):
return self.config.global_model.get('owner', 'tmp')
@ -638,6 +644,7 @@ class Config:
# config
def __init__(self,
dico):
self._unrestraint = False
if DEBUG:
from pprint import pprint
pprint(dico)
@ -662,6 +669,7 @@ class Config:
self.root = first_path.rsplit('.', 1)[0]
else:
self.root = ''
self.dico = dico
def __getattr__(self,
subfunc: str) -> Any:
@ -676,6 +684,11 @@ class Config:
if subfunc == 'owner':
return ContextOwner(self,
self.schema)
if subfunc == 'unrestraint':
ret = Config(self.dico)
ret._unrestraint = True
ret.temp = self.temp
return ret
raise APIError(_('please specify a valid sub function ({})').format(subfunc))
def add_value(self,
@ -805,12 +818,16 @@ class Config:
subpaths = path.split('.')[len(root):]
else:
subpaths = path.split('.')
current_subpath = 'root'
for subpath in subpaths:
if root_path:
root_path += '.' + subpath
else:
root_path = subpath
schema = schema['properties'][root_path]
schema = schema['properties'].get(root_path)
if schema is None:
raise AttributeError(_('option "{0}" inconnue dans l\'optiondescription "{1}"').format(subpath, current_subpath))
current_subpath = subpath
return schema
def isleader(self,
@ -837,6 +854,8 @@ class Config:
path: str,
index: Optional[int],
permissive: bool=False) -> bool:
if self._unrestraint:
return False
if permissive:
property_ = 'hidden'
needs = True

View File

@ -1,6 +1,6 @@
try:
from tiramisu.error import APIError, ValueWarning, ValueOptionError, ValueErrorWarning, PropertiesOptionError, ConfigError, display_list
except ModuleNotFoundError:
except ImportError:
import weakref
from .i18n import _
@ -130,7 +130,7 @@ except ModuleNotFoundError:
if self.msg:
return self.msg
if self._option_bag is None:
return "unknown error"
return "option désactivée"
req = self._settings.apply_requires(self._option_bag,
True)
# if req != {} or self._orig_opt is not None:

View File

@ -1,6 +1,6 @@
try:
from tiramisu.i18n import _
except ModuleNotFoundError:
except ImportError:
# FIXME
def _(val):
return val

View File

@ -1,6 +1,6 @@
try:
from tiramisu.setting import undefined
except ModuleNotFoundError:
except ImportError:
class Undefined(object):
def __str__(self):
return 'Undefined'