python 3.5 support
[tiramisu.git] / test / test_choice_option.py
index f636acc..6094f2e 100644 (file)
@@ -1,5 +1,5 @@
 # coding: utf-8
-from autopath import do_autopath
+from .autopath import do_autopath
 do_autopath()
 
 from tiramisu.setting import owners
@@ -22,6 +22,10 @@ def return_calc_list(val):
     return [val]
 
 
+def return_error():
+    raise Exception('test')
+
+
 def test_choiceoption_function():
     ch = ChoiceOption('ch', '', values=return_list)
     od = OptionDescription('od', '', [ch])
@@ -35,6 +39,16 @@ def test_choiceoption_function():
     assert cfg.getowner(ch) == owners.default
     raises(ValueError, "cfg.ch='no'")
     assert cfg.getowner(ch) == owners.default
+    assert ch.impl_get_values(None) == []
+    assert ch.impl_get_values(cfg) == ['val1', 'val2']
+
+
+def test_choiceoption_function_error():
+    ch = ChoiceOption('ch', '', values=return_error)
+    od = OptionDescription('od', '', [ch])
+    cfg = Config(od)
+    cfg.read_write()
+    raises(Exception, "cfg.ch = 'no'")
 
 
 def test_choiceoption_calc_function():
@@ -68,6 +82,15 @@ def test_choiceoption_calc_opt_function():
     assert cfg.getowner(ch) == owners.default
 
 
+def test_choiceoption_calc_opt_function_propertyerror():
+    st = StrOption('st', '', 'val1', properties=('disabled',))
+    ch = ChoiceOption('ch', "", values=return_calc_list, values_params={'': ((st, False),)})
+    od = OptionDescription('od', '', [st, ch])
+    cfg = Config(od)
+    cfg.read_write()
+    raises(ValueError, "cfg.ch='no'")
+
+
 def test_choiceoption_calc_opt_multi_function():
     st = StrOption('st', '', ['val1'], multi=True)
     ch = ChoiceOption('ch', "", default_multi='val2', values=return_val, values_params={'': ((st, False),)}, multi=True)