optimisations and all is properties
[tiramisu.git] / test / test_option_owner.py
index bf29f92..5bdbf38 100644 (file)
@@ -3,31 +3,10 @@ import autopath
 from py.test import raises
 from tiramisu.config import *
 from tiramisu.option import *
+from tiramisu.setting import owners
 
 def make_description():
     gcoption = ChoiceOption('name', 'GC name', ['ref', 'framework'], 'ref')
-    gcdummy = BoolOption('dummy', 'dummy', callback="toto")
-    objspaceoption = ChoiceOption('objspace', 'Object space',
-                                ['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)
-    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,
-                                    requires=['boolop'])
-    wantframework_option = BoolOption('wantframework', 'Test requires',
-                                      default=False,
-                                      requires=['boolop'])
-    gcgroup = OptionDescription('gc', '', [gcoption, gcdummy, floatoption])
-    descr = OptionDescription('constraints', '', [gcgroup, booloption, objspaceoption,
-                                           wantref_option, stroption,
-                                           wantframework_option,
-                                           intoption, boolop])
-    return descr
-
-def make_description2():
-    gcoption = ChoiceOption('name', 'GC name', ['ref', 'framework'], 'ref')
     gcdummy = BoolOption('dummy', 'dummy', default=False)
     objspaceoption = ChoiceOption('objspace', 'Object space',
                                 ['std', 'thunk'], 'std')
@@ -36,55 +15,47 @@ def make_description2():
     floatoption = FloatOption('float', 'Test float option', default=2.3)
     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,
-                                    requires=['boolop'])
+    wantref_option = BoolOption('wantref', 'Test requires', default=False)
     wantframework_option = BoolOption('wantframework', 'Test requires',
-                                      default=False,
-                                      requires=['boolop'])
+                                      default=False)
+
     gcgroup = OptionDescription('gc', '', [gcoption, gcdummy, floatoption])
-    descr = OptionDescription('constraints', '', [gcgroup, booloption, objspaceoption,
+    descr = OptionDescription('tiram', '', [gcgroup, booloption, objspaceoption,
                                            wantref_option, stroption,
                                            wantframework_option,
                                            intoption, boolop])
     return descr
 
-def test_override_are_default_owner():
-    "config.override() implies that the owner is 'default' again"
-    descr = make_description2()
-    config = Config(descr, bool=False)
-    # default
-    assert config.gc._cfgimpl_value_owners['dummy'] == 'default'
-    # user
-    config.gc.dummy = True
-    assert config.gc._cfgimpl_value_owners['dummy'] == 'user'
-    assert config._cfgimpl_values['gc']._cfgimpl_value_owners['dummy'] == 'user'
-    #Options have an available default setting and can give it back
-    assert config._cfgimpl_descr._children[0]._children[1].getdefault() == False
-    config.override({'gc.dummy':True})
-    assert config.gc._cfgimpl_value_owners['dummy'] == 'default'
-    # user again
-    config.gc.dummy = False
-    assert config.gc._cfgimpl_value_owners['dummy'] == 'user'
-
-def test_has_callback():
-    descr = make_description()
-    # here the owner is 'default'
-    config = Config(descr, bool=False)
-    # because dummy has a callback 
-    dummy = config.unwrap_from_path('gc.dummy')
-    dummy.freeze()
-    raises(TypeError, "config.gc.dummy = True")
-
-#____________________________________________________________
-def test_has_callback_with_setoption():
-    descr = make_description()
-    config = Config(descr, bool=False)
-    dummy = config.unwrap_from_path('gc.dummy')
-    dummy.freeze()
-    raises(TypeError, "config.gc.setoption('dummy', True, 'gen_config')")
-
-def test_cannot_override():
-    descr = make_description()
-    config = Config(descr, bool=False)
-    raises(TypeError, "config.override({'gc.dummy': True})")
-
+def test_default_owner():
+    gcdummy = BoolOption('dummy', 'dummy', default=False)
+    descr = OptionDescription('tiramisu', '', [gcdummy])
+    cfg = Config(descr)
+    assert cfg.dummy == False
+    dm = cfg.unwrap_from_path('dummy')
+    assert cfg.cfgimpl_get_values().getowner(dm) == 'default'
+    cfg.dummy = True
+    assert cfg.cfgimpl_get_values().getowner(dm) == owners.user
+
+def test_add_owner():
+    gcdummy = BoolOption('dummy', 'dummy', default=False)
+    descr = OptionDescription('tiramisu', '', [gcdummy])
+    cfg = Config(descr)
+    assert cfg.dummy == False
+    dm = cfg.unwrap_from_path('dummy')
+    assert cfg.cfgimpl_get_values().getowner(dm) == 'default'
+    owners.add_owner("gen_config")
+    cfg.cfgimpl_get_settings().setowner(owners.gen_config)
+    cfg.dummy = True
+    assert cfg.cfgimpl_get_values().getowner(dm) == owners.gen_config
+
+def test_owner_is_not_a_string():
+    gcdummy = BoolOption('dummy', 'dummy', default=False)
+    descr = OptionDescription('tiramisu', '', [gcdummy])
+    cfg = Config(descr)
+    assert cfg.dummy == False
+    dm = cfg.unwrap_from_path('dummy')
+    assert cfg.cfgimpl_get_values().getowner(dm) == owners.default
+    assert cfg.cfgimpl_get_values().getowner(dm) == 'default'
+    assert isinstance(cfg.cfgimpl_get_values().getowner(dm), owners.Owner)
+    cfg.dummy = True
+    assert cfg.cfgimpl_get_values().getowner(dm) == 'user'