add option name's validation and rename Option method with objimpl_
[tiramisu.git] / test / test_config_api.py
index 492c7f8..599776d 100644 (file)
@@ -2,14 +2,16 @@
 import autopath
 from py.test import raises
 
-from tiramisu.config import *
-from tiramisu.option import *
+from tiramisu.config import Config
+from tiramisu.option import IntOption, FloatOption, StrOption, ChoiceOption, \
+    BoolOption, OptionDescription
+
 
 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')
+                                  ('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)
@@ -20,9 +22,9 @@ def make_description():
 
     gcgroup = OptionDescription('gc', '', [gcoption, gcdummy, floatoption])
     descr = OptionDescription('tiramisu', '', [gcgroup, booloption, objspaceoption,
-                                           wantref_option, stroption,
-                                           wantframework_option,
-                                           intoption, boolop])
+                                               wantref_option, stroption,
+                                               wantframework_option,
+                                               intoption, boolop])
     return descr
 
 
@@ -34,86 +36,47 @@ def test_compare_configs():
     conf2.wantref = True
     assert conf1 != conf2
     assert hash(conf1) != hash(conf2)
-    assert conf1.getkey() != conf2.getkey()
+    #assert conf1.getkey() != conf2.getkey()
     conf1.wantref = True
     assert conf1 == conf2
     assert hash(conf1) == hash(conf2)
-    assert conf1.getkey() == conf2.getkey()
+    #assert conf1.getkey() == conf2.getkey()
+    conf2.gc.dummy = True
+    assert conf1 != conf2
+    assert hash(conf1) != hash(conf2)
+    #assert conf1.getkey() != conf2.getkey()
+    conf1.gc.dummy = True
+    assert conf1 == conf2
+    assert hash(conf1) == hash(conf2)
+    #assert conf1.getkey() == conf2.getkey()
 # ____________________________________________________________
 
+
 def test_iter_config():
     "iteration on config object"
     s = StrOption("string", "", default="string")
     s2 = StrOption("string2", "", default="string2")
-    descr = OptionDescription("options", "", [s,s2])
+    descr = OptionDescription("options", "", [s, s2])
     config = Config(descr)
     assert [(name, value) for name, value in config] == \
-    [('string', 'string'), ('string2', 'string2')]
+        [('string', 'string'), ('string2', 'string2')]
+
 
 def test_iter_subconfig():
     "iteration on config sub object"
     descr = make_description()
     conf = Config(descr)
     for (name, value), (gname, gvalue) in \
-        zip(conf.gc, [("name", "ref"), ("dummy", False)]):
+            zip(conf.gc, [("name", "ref"), ("dummy", False)]):
         assert name == gname
         assert value == gvalue
 
-def test_cfgimpl_get_value():
-    "same as getattr."
-    descr = make_description()
-    conf = Config(descr)
-    #FIXME
-    #assert conf.cfgimpl_get_value(('gc', 'dummy')) == False
-
-#____________________________________________________________
-def test_getpaths():
-    descr = make_description()
-    config = Config(descr)
-
-    assert config.getpaths() == ['gc.name', 'gc.dummy', 'gc.float', 'bool',
-                                 'objspace', 'wantref', 'str', 'wantframework',
-                                 'int', 'boolop']
-    assert config.getpaths() == descr.getpaths()
-    assert config.gc.getpaths() == ['name', 'dummy', 'float']
-    assert config.gc.getpaths() == descr.gc.getpaths()
-    assert config.getpaths(include_groups=True) == [
-        'gc', 'gc.name', 'gc.dummy', 'gc.float',
-        'bool', 'objspace', 'wantref', 'str', 'wantframework', 'int', 'boolop']
-
-    assert config.getpaths(True) == descr.getpaths(True)
-
-def test_getpaths_with_hidden():
-    objspaceoption = ChoiceOption('objspace', 'Object space',
-                                ('std', 'thunk'), 'std')
-    booloption = BoolOption('bool', 'Test boolean option', default=True, properties=('hidden',))
-    intoption = IntOption('int', 'Test int option', default=0)
-    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)
-
-    descr = OptionDescription('tiramisu', '', [booloption, objspaceoption,
-                                           wantref_option, stroption,
-                                           wantframework_option,
-                                           intoption, boolop])
-
-    config = Config(descr)
-    result = ['bool', 'objspace', 'wantref', 'str', 'wantframework', 'int', 'boolop']
-    assert config.getpaths() == result
-    r2 = ['bool', 'objspace', 'wantref', 'str', 'wantframework', 'int', 'boolop']
-    assert config.getpaths(allpaths=True) == r2
 
 def test_str():
     descr = make_description()
     c = Config(descr)
-    c # does not crash
+    c  # does not crash
 
-#def test_dir():
-#    descr = make_description()
-#    c = Config(descr)
-#    print dir(c)
 
 def test_make_dict():
     "serialization of the whole config to a dict"
@@ -131,19 +94,6 @@ def test_make_dict():
     d2 = config.make_dict(flatten=True)
     assert d2 == {'a': True, 'int': 43}
 
-#def test_delattr():
-#    "delattr, means suppression of an option in a config"
-#    descr = OptionDescription("opt", "", [
-#    OptionDescription("s1", "", [
-#        BoolOption("a", "", default=False)]),
-#    IntOption("int", "", default=42)])
-#    c = Config(descr)
-#    c.int = 45
-#    assert c.int == 45
-#    del c.int
-#    assert c.int == 42
-#    c.int = 45
-#    assert c.int == 45
 
 def test_find_in_config():
     "finds option in config"
@@ -164,36 +114,8 @@ def test_find_in_config():
     #assert conf.find_first(byattrs= dict(default=2.3)) == conf.unwrap_from_path('gc.float')
     #assert conf.find_first(byvalue=False, byname='dummy', byattrs=dict(default=False)) == conf.unwrap_from_path('gc.dummy')
 
+
 def test_does_not_find_in_config():
     descr = make_description()
     conf = Config(descr)
     raises(AttributeError, "conf.find(byname='IDontExist')")
-
-#def test_validator():
-#    "validates the integrity of an option towards a whole configuration"
-#    def my_validator_1(config):
-#        assert config is c
-
-#    def my_validator_2(config):
-#        assert config is c
-#        raise ConflictConfigError
-
-#    descr = OptionDescription("opt", "", [
-#        BoolOption('booloption1', 'option test1', default=False,
-#                   validator=my_validator_1),
-#        BoolOption('booloption2', 'option test2', default=False,
-#                   validator=my_validator_2),
-#        BoolOption('booloption4', 'option test4', default=False,
-#                   ),
-#        ])
-#    c = Config(descr)
-#    c.booloption1 = True
-##    raises(ConfigError, "c.booloption2 = True")
-##    assert c.booloption2 is False
-##    raises(ConfigError, "c.booloption3 = True")
-#    assert c.booloption2 is False
-#    c.booloption4 = True
-#    assert c.booloption2 is False
-#    c.booloption2 = False
-#    assert c.booloption2 is False
-#