"""these tests are here to create some :class:`tiramisu.option.Option`'s and to compare them """ from .autopath import do_autopath do_autopath() from py.test import raises from tiramisu.error import APIError, ConfigError from tiramisu import IntOption, OptionDescription, Config from tiramisu.setting import groups def a_func(): return None def test_option_valid_name(): IntOption('test', '') raises(ValueError, 'IntOption(1, "")') raises(ValueError, 'IntOption("1test", "")') IntOption("test1", "") raises(ValueError, 'IntOption("impl_test", "")') raises(ValueError, 'IntOption("_test", "")') raises(ValueError, 'IntOption(" ", "")') def test_option_with_callback(): #no default value with callback raises(ValueError, "IntOption('test', '', default=1, callback=a_func)") def test_option_get_information(): description = "it's ok" string = 'some informations' i = IntOption('test', description) raises(ValueError, "i.impl_get_information('noinfo')") i.impl_set_information('info', string) assert i.impl_get_information('info') == string raises(ValueError, "i.impl_get_information('noinfo')") assert i.impl_get_information('noinfo', 'default') == 'default' assert i.impl_get_information('doc') == description assert i.impl_getdoc() == description def test_option_get_information_config(): description = "it's ok" string = 'some informations' string i = IntOption('test', description) od = OptionDescription('od', '', [i]) Config(od) raises(ValueError, "i.impl_get_information('noinfo')") raises(AttributeError, "i.impl_set_information('info', string)") # assert i.impl_get_information('info') == string raises(ValueError, "i.impl_get_information('noinfo')") assert i.impl_get_information('noinfo', 'default') == 'default' assert i.impl_get_information('doc') == description assert i.impl_getdoc() == description def test_option_get_information_config2(): description = "it's ok" string = 'some informations' i = IntOption('test', description) i.impl_set_information('info', string) od = OptionDescription('od', '', [i]) Config(od) raises(ValueError, "i.impl_get_information('noinfo')") raises(AttributeError, "i.impl_set_information('info', 'hello')") assert i.impl_get_information('info') == string raises(ValueError, "i.impl_get_information('noinfo')") assert i.impl_get_information('noinfo', 'default') == 'default' assert i.impl_get_information('doc') == description assert i.impl_getdoc() == description def test_optiondescription_get_information(): description = "it's ok" string = 'some informations' o = OptionDescription('test', description, []) o.impl_set_information('info', string) assert o.impl_get_information('info') == string raises(ValueError, "o.impl_get_information('noinfo')") assert o.impl_get_information('noinfo', 'default') == 'default' assert o.impl_get_information('doc') == description assert o.impl_getdoc() == description def test_option_multi(): IntOption('test', '', multi=True) IntOption('test', '', multi=True, default_multi=1) IntOption('test', '', default=[1], multi=True, default_multi=1) #add default_multi to not multi's option raises(ValueError, "IntOption('test', '', default_multi=1)") #unvalid default_multi raises(ValueError, "IntOption('test', '', multi=True, default_multi='yes')") #not default_multi with callback raises(ValueError, "IntOption('test', '', multi=True, default_multi=1, callback=a_func)") def test_unknown_option(): i = IntOption('test', '') od1 = OptionDescription('od', '', [i]) od2 = OptionDescription('od', '', [od1]) api = Config(od2) # test is an option, not an optiondescription raises(TypeError, "api.option('od.test.unknown').value.get()") # unknown is an unknown option raises(AttributeError, "api.option('unknown').value.get()") # unknown is an unknown option raises(AttributeError, "api.option('od.unknown').value.get()") # unknown is an unknown optiondescription raises(AttributeError, "api.option('od.unknown.suboption').value.get()") def test_optiondescription_group(): groups.notfamily = groups.GroupType('notfamily') i = IntOption('test', '') i2 = IntOption('test', '') od1 = OptionDescription('od', '', [i]) od1.impl_set_group_type(groups.family) od3 = OptionDescription('od2', '', [i2]) od3.impl_set_group_type(groups.notfamily) od2 = OptionDescription('od', '', [od1, od3]) api = Config(od2) assert len(list(api.option.list('optiondescription'))) == 2 assert len(list(api.option.list('optiondescription', group_type=groups.family))) == 1 assert len(list(api.option.list('optiondescription', group_type=groups.notfamily))) == 1 def test_optiondescription_group_redefined(): try: groups.notfamily = groups.GroupType('notfamily') except: pass i = IntOption('test', '') od1 = OptionDescription('od', '', [i]) od1.impl_set_group_type(groups.family) raises(ValueError, "od1.impl_set_group_type(groups.notfamily)") def test_optiondescription_group_masterslave(): i = IntOption('test', '') od1 = OptionDescription('od', '', [i]) raises(ConfigError, "od1.impl_set_group_type(groups.master)") def test_asign_optiondescription(): i = IntOption('test', '') od1 = OptionDescription('od', '', [i]) od2 = OptionDescription('od', '', [od1]) api = Config(od2) raises(APIError, "api.option('od').value.set('test')") raises(APIError, "api.option('od').value.reset()") def test_intoption(): i1 = IntOption('test1', 'description', min_number=3) i2 = IntOption('test2', 'description', max_number=3) od = OptionDescription('od', '', [i1, i2]) cfg = Config(od) raises(ValueError, "cfg.option('test1').value.set(2)") cfg.option('test1').value.set(3) cfg.option('test1').value.set(4) cfg.option('test2').value.set(2) cfg.option('test2').value.set(3) raises(ValueError, "cfg.option('test2').value.set(4)")