Commit Graph

840 Commits

Author SHA1 Message Date
15d94d5fff domainname with only one character is now allowed 2015-10-12 17:06:15 +02:00
3aad913868 check with option as parameter 2015-09-17 21:25:32 +02:00
5ea92d3460 need new settings when create fake_config 2015-09-17 19:14:56 +02:00
9da7e89176 empty property only available for multi 2015-07-27 09:32:42 +02:00
8e7a32de08 add global 'empty' property, this property raise mandatory PropertiesOptionError if multi or master have empty value 2015-07-26 19:13:25 +02:00
44cd618704 remove pep8 validation errors 2015-07-24 17:54:10 +02:00
6cc74506fb Some optimisations 2015-05-03 09:56:03 +02:00
487b99b32c for a multi mandatory, allow [] with allow_empty_list attribut 2015-04-20 14:49:43 +02:00
072246a203 URLOption: allow uppercase in resource name 2015-04-19 09:46:39 +02:00
2c6275ffbd remove slave values when delete a master without value 2015-04-19 09:37:46 +02:00
6fc921fc19 difference between option/optiondescription in PropertiesOptionError message 2015-04-19 09:25:49 +02:00
2b019027be valid Option is an unicode or a string if needed 2015-04-19 09:15:18 +02:00
057bba83e4 ValueError if not PropertieError 2015-04-18 23:46:37 +02:00
d959020eed ability to disable warnings validation 2015-04-18 23:11:57 +02:00
10768a6067 refactor validation 2015-04-18 22:53:45 +02:00
c566ad1111 valid default/callback value in consistencies 2015-03-08 12:03:49 +01:00
85297d8c4d test uppercase character before valid domain name for better error message 2014-12-07 14:51:51 +01:00
bc65caa4dc mandatory master/slave's consistency with default value as slave 2014-12-07 14:39:23 +01:00
4fde28a15e in_network's consistency now verify that IP is not network or broadcast's IP + ip_netmask's consistency now verify that IP is not broadcast's IP 2014-12-01 23:16:00 +01:00
a801951a78 can reset slave value in all case when deleting master value 2014-12-01 23:08:56 +01:00
71e69cd0bf if consistency with multiple option return if transitive 2014-12-01 23:02:55 +01:00
7646071efd propertyerror are transitive in consistency, now it's possible to set non-transitive consistency 2014-12-01 22:58:53 +01:00
2ccf92f879 improve GroupConfig/MetaConfig
add set_value in GroupConfig
2014-12-01 21:49:50 +01:00
c6c331eb54 in find_firsts get option only one time 2014-11-11 11:31:23 +01:00
7c5b6e2db2 improve performance 2014-11-10 23:15:08 +01:00
f03cbeadb7 better performance in find_firsts
_is_build_cache not set in dictionary storage
2014-11-10 21:00:30 +01:00
4217508f3f works on sqlalchemy storage 2014-11-10 09:13:44 +01:00
c75867720f add force_permissive in mandatory_warnings 2014-10-26 16:39:24 +01:00
f730050f7c pass force_permissive to slave for a master or to master for a slave 2014-10-26 16:19:06 +01:00
4310d59991 add force_permissive to config __iter__ 2014-10-26 10:26:23 +01:00
a130cff4bf frozen with force_default_on_freeze can change owner 2014-10-26 09:44:06 +01:00
ed3373cff0 bad characters in DomainnameOption could be in warning level 2014-10-26 09:38:17 +01:00
8a59e27396 f option is frozen with force_default_on_freeze property, owner must be 'default' check property when tried to change owner 2014-10-26 08:51:45 +01:00
0728625afd add consistency name in error if consistency not exists 2014-10-25 23:00:04 +02:00
9ad6cd905c allow number as first letter of a domainname with netbios type 2014-10-25 22:58:46 +02:00
471af4fd75 cannot add unvalaible consistency for an option 2014-10-25 22:48:42 +02:00
8f950620f7 tiramisu/i18n.py : Removing call of gettext.install
This call make translation fail in gen_config, the new way to use
gettext don't need to use this call.

Conflicts:
	tiramisu/i18n.py
2014-10-25 22:23:55 +02:00
gwen
44c96f3a60 replace ugettext by a simple gettext 2014-10-25 22:22:00 +02:00
gwen
a408a583fb i18n with ugettext instead of gettext 2014-10-25 22:21:23 +02:00
9f3d676280 reduce memory usage 2014-10-25 22:11:31 +02:00
58c22aa70f better support for sqlalchemy storage 2014-07-06 15:35:13 +02:00
71f8926fca better support for sqlalchemy storage 2014-07-06 15:31:57 +02:00
3cc2d9ca3d add TIRAMISU_STORAGE environment variable 2014-06-20 16:29:38 +02:00
b64189f763 add DynOptionDescription 2014-06-19 23:22:39 +02:00
888446e4c5 remove unjustified open_values parameters in ChoiceOption 2014-04-27 10:44:19 +02:00
31fff062e1 Values in ChoiceOption can be a function now 2014-04-27 10:36:47 +02:00
9112a8c5b0 add SubMulti 2014-04-26 22:37:01 +02:00
b6a0f188b2 force_store_value now support Multi 2014-04-18 21:33:15 +02:00
22860099ba report/generate.py: corrections 2014-04-17 18:47:48 +02:00
6d8137160c 'getattr' in optiondescription can return a bound method 2014-04-15 21:48:31 +02:00
9bec52273a we can pickle object 2014-04-14 22:53:40 +02:00
a1753afb8c add consistencies's storage 2014-04-13 10:35:43 +02:00
66c82ee582 Merge branch 'orm' of ssh://git.labs.libre-entreprise.org/gitroot/tiramisu into orm 2014-04-13 10:31:51 +02:00
5d8b5719a0 Merge branch 'master' into orm
Conflicts:
	test/test_config_api.py
	tiramisu/autolib.py
	tiramisu/config.py
	tiramisu/option.py
	tiramisu/value.py
2014-04-13 10:30:42 +02:00
bf180bc115 add missing file 2014-04-12 23:13:28 +02:00
299e51e806 start works on storage 2014-04-12 22:47:52 +02:00
aa0734591d change None to undefined when it's needed 2014-04-12 21:57:17 +02:00
3ab0688c46 Arity change, remove force_properties:
* tiramisu/config.py (in cfgimpl_get_home_by_path and getattr)
 * tiramisu/value.py (in getitem):
2014-04-12 21:37:20 +02:00
cd4d3527c7 split tiramisu/option.py and add MasterSlaves object 2014-04-12 17:55:13 +02:00
d1e86f6d48 Merge branch 'log' 2014-04-03 22:16:08 +02:00
da434a4273 add logger in validation 2014-04-03 22:15:41 +02:00
a1f0c29713 Merge modification made for 1.0's branch 2014-04-02 12:06:11 +02:00
76a43a7ff9 if slave has a callback with a slave that has a callback with a default_multi's slave, now it's works 2014-04-02 12:04:50 +02:00
463fc8e88a if opt is freeze with force_default_on_freeze, didn't remove store value 2014-04-01 21:01:01 +02:00
967a48412d Merge branch '_getattr' 2014-04-01 09:51:43 +02:00
0b2e5f90e2 same arity for _getattr and getattr 2014-04-01 09:51:25 +02:00
1ae6f0c6e8 Merge branch 'mandatory' 2014-04-01 09:29:34 +02:00
150b490200 config.mandatory_warnings return always None 2014-04-01 09:29:07 +02:00
a3c5e6034f Merge branch 'force_permissive'
Conflicts:
	test/test_freeze.py
2014-03-31 22:38:56 +02:00
cd52729952 add force_permissive in config's method (iter_all, iter_group, find, find_first and make_dict)
rename _getattr to getattr
2014-03-31 22:34:57 +02:00
ff5376a382 properties are check now in getowner
get_modified_values works good with force_store_value
2014-03-29 20:31:56 +01:00
712db2875e force_store_value works now with permissive 2014-03-28 17:36:02 +01:00
84f0095c2f update translation 2014-03-26 20:48:06 +01:00
835d6d6da0 context could be useful in a callback, now we can retrieve context in a function (be careful to infinite loop) 2014-03-26 19:47:42 +01:00
b3d04a1f68 update warning's message 2014-03-24 21:18:43 +01:00
a04a61f1a4 Merge branch 'master' into lgpl 2014-03-15 10:11:17 +01:00
f7d31bfa92 Merge branch 'master' into force-cache
Conflicts:
	translations/fr/tiramisu.po
	translations/tiramisu.pot
2014-03-15 10:09:19 +01:00
f43ef2dafe now there are two warnings_only's level:
- option's level for validation and _second_level_validation
- consistencies level
2014-03-13 14:12:44 +01:00
88b5af9810 Merge branch 'master' into better_warnings 2014-03-12 22:13:20 +01:00
ff802b46e5 consistencies can make a warning instead of raises
for that, you have to set something like:
  a.impl_add_consistency('not_equal', b, warnings_only=True)

warning product now adapted message
2014-03-12 21:56:53 +01:00
544cd93c73 can make_dict with disabled suboption 2014-03-12 14:57:36 +01:00
d7b04ebed0 add consistency in_network for IPOption
This new consistency can validate that an IPv4 is a specified (network/netmask) network
2014-03-11 18:57:19 +01:00
db9ab7a1e9 test if cache property is not set in config when force_cache 2014-03-09 20:22:29 +01:00
6f4a881320 Merge branch 'master' into force-cache 2014-03-09 20:14:32 +01:00
f2154e2322 update translation 2014-03-09 20:14:17 +01:00
6e8b570a37 mandatory_warnings is now in values and add force_cache to values 2014-03-09 20:06:44 +01:00
d3f9d20ab5 add extend in config setting 2014-03-08 18:53:22 +01:00
c175519211 pep8 2014-03-06 22:09:44 +01:00
9f903d3e04 add username's option 2014-03-06 22:09:12 +01:00
gwen
f3a826a8d7 Merge branch 'master' of ssh://git.labs.libre-entreprise.org/gitroot/tiramisu 2014-02-25 16:19:49 +01:00
gwen
0c9d6554ae a hostname shall not start with a number 2014-02-25 15:20:03 +01:00
gwen
716d2b2348 allows a DomainnameOption to start with a number 2014-02-25 15:16:15 +01:00
d5b83c123c tiramisu/setting.py : properties store in cache was a reference to a list modified in validation, should copy properties in cache 2014-02-20 16:55:35 +01:00
bf0501b1d6 tiramisu/setting.py : properties store in cache was a reference to a list modified in validation, should copy properties in cache 2014-02-20 14:27:29 +01:00
8d751ecc9b valid port type before compare to min and max value 2014-02-17 18:36:29 +01:00
fc7f3c24a5 properties option in consistencies are now allowed
Conflicts:
	tiramisu/option.py (PortOption._validate): Strange try/except
	removed.
2014-02-17 17:45:37 +01:00
194c82faad tests pass now with dictionary and sqlalchemy storage 2014-02-16 23:37:27 +01:00
21c8ed5d76 Merge branch 'master' into orm
Conflicts:
	test/test_option_consistency.py
	test/test_state.py
	tiramisu/option.py
2014-02-06 22:24:50 +01:00
e7531e1fda more tests 2014-02-06 22:17:20 +01:00
72f06bc29d properties option in consistencies are now allowed 2014-02-06 19:19:48 +01:00
Daniel Dehennin
f8ac263c86 Hotfix release 1.0~2.4.1
-----BEGIN PGP SIGNATURE-----
 Version: GnuPG v1
 
 iF4EABEKAAYFAlLyBpcACgkQWjgIUPVihwwhyQD/Ri/R6wO/zk49ILx5UzPdDDcU
 UCWxsKvbCIloO76BMcIA/0nx/6PUVc/v3iag5reNvtrXJQzdKlprmkjvBhLalVJS
 =w09x
 -----END PGP SIGNATURE-----

Merge tag 'release/1.0_2.4.1'

Hotfix release 1.0~2.4.1
2014-02-05 11:22:17 +01:00
6f5d471db1 if option with requires has a property, calculated properties are store in storage 2014-02-05 10:37:39 +01:00
5febdf3a3f set self._extra before 'super' 2014-02-04 21:55:57 +01:00
98bd35ad36 Merge branch 'master' into orm
Conflicts:
	tiramisu/config.py
	tiramisu/option.py
2014-02-04 21:54:30 +01:00
c52b2f84f4 if option with requires has a property, calculated properties are store in storage 2014-02-04 21:40:07 +01:00
a067d2cdd9 add some tests 2014-02-04 21:14:30 +01:00
5646fc35a2 Merge branch 'master' into orm
Conflicts:
	test/test_parsing_group.py
2014-02-03 22:11:58 +01:00
8d10ad4002 add tests 2014-02-02 22:47:46 +01:00
5897231421 Merge branch 'master' into orm
Conflicts:
	test/test_dereference.py
	test/test_state.py
	tiramisu/config.py
	tiramisu/value.py
2014-02-02 18:52:13 +01:00
26158fc3c4 update test for metaconfig serialization 2014-02-02 18:33:21 +01:00
f8faec408f Merge branch 'master' into metaconfig 2014-02-02 18:21:22 +01:00
683e40fbb5 when change len of calculated master, change len of slave too 2014-02-02 18:20:01 +01:00
8709386570 __getattr__ OD 2014-02-01 18:35:18 +01:00
313b03b246 cache in sql works 2014-02-01 16:26:23 +01:00
02a987b39d sqlalchemy 2014-01-30 22:55:15 +01:00
2eb63c917b active callback's slave verification 2014-01-28 09:14:56 +01:00
217a1989c7 validator in sqlalchemy 2014-01-27 23:28:22 +01:00
a1dd2cfce7 require works well in sqlalchemy storage 2014-01-27 17:16:05 +01:00
d3f42efe85 typo 2014-01-25 18:38:51 +01:00
880b6366eb Merge branch 'master' into orm
Conflicts:
	tiramisu/setting.py
2014-01-25 16:39:32 +01:00
138018dfe9 if we delete all reference to a Config and we have reference to old SubConfig, Values, Multi or Settings, make a ConfigError instead of AttributError on NoneType object 2014-01-25 11:20:11 +01:00
cbfb5a45b0 Merge branch 'master' into orm 2014-01-25 10:22:17 +01:00
3b3e5216fe cache 2014-01-25 10:15:25 +01:00
gwen
21a67971c5 typo propertive -> property 2014-01-24 09:17:46 +01:00
3b0b3cdfd9 p8p 2014-01-20 14:58:48 +01:00
661f844ce6 sqlalchemy has a storage 2014-01-20 14:53:14 +01:00
068f68460d Merge branch 'master' into orm 2014-01-18 10:25:09 +01:00
9d92ab84d7 regression: permissive for option is apply every time, not only when global permissive is set 2014-01-16 09:49:37 +01:00
eabe3bc55f corrections 2014-01-16 09:28:10 +01:00
36cd79058f use polymorphism 2014-01-09 21:42:32 +01:00
cde04d654a Merge branch 'master' into orm
Conflicts:
	tiramisu/setting.py
2014-01-09 20:32:17 +01:00
gwen
40ecddf242 docstring 2014-01-06 15:32:28 +01:00
gwen
3c36e05d82 adds test for an API 2014-01-06 14:40:29 +01:00
gwen
f0ecbf4914 adds an extend API for the settings 2014-01-06 14:32:56 +01:00
172a33f842 mandatory_warnings never raises ConfigError 2013-12-16 14:20:35 +01:00
64ca069a0b Merge branch 'master' into orm
Conflicts:
	test/test_config.py
	tiramisu/autolib.py
	tiramisu/option.py
	tiramisu/value.py
2013-12-12 17:50:42 +01:00
1e880f4bc6 remove unused code 2013-12-09 18:48:44 +01:00
73745be440 Important behavior change : to add default_multi value, now use Multi.append(), not Multi.append(None) 2013-12-09 17:59:39 +01:00
bb1f6947e3 better name's validation 2013-12-09 17:55:52 +01:00
0f966f6d26 check if permissive is in global properties before allow permissive for an option 2013-12-09 15:29:37 +01:00
20bef5ff04 Important behavior change in callback with multi.
Before, tiramisu iterable multi's callback_params in all cases.
Now, this append only if multi's callback_params are in master/slave group.
2013-12-09 15:08:14 +01:00
gwen
deb174f36e imprecise error message 2013-12-05 09:59:07 +01:00
e153cf0e28 no more used and_ 2013-12-04 16:28:11 +01:00
gwen
5fb79fed38 an error message has been deleted by error, ref #6740 2013-12-04 15:55:53 +01:00
gwen
48b662997e an error message has been deleted by error 2013-12-04 15:48:19 +01:00
gwen
029452ccbc validation of an ip if an ip term starts with a zero 2013-12-02 15:10:05 +01:00
374c56a9c8 first version with sqlalchemy option's storage 2013-11-23 23:34:17 +01:00
gwen
384b30210c find and find_first's new argument 2013-11-04 17:15:47 +01:00
b606d23801 add imp_meta 2013-10-15 18:23:36 +02:00
615cad4b49 EmailOption and URLOption : let user choose attr for DomainnameOption 2013-10-01 20:01:38 +02:00
eb3327cd75 correction in allow_without_dot + test 2013-10-01 10:13:17 +02:00
2dcdbb137e rename FileOption to FilenameOption
python 3 support
2013-10-01 08:19:10 +02:00
0a83a9261f update invalid's message and display all informations when raises 2013-09-30 22:56:08 +02:00
c8a20eefb5 update invalid's message and display all informations when raises 2013-09-30 22:54:46 +02:00
cce080cbd3 add FileOption 2013-09-30 21:21:47 +02:00
1a294e3d09 refactor DomainnameOption
add options EmailOption and URLOption
2013-09-30 19:41:56 +02:00
feeb9842f5 serialize metaconfig/groupconfig 2013-09-30 16:22:08 +02:00
6b7db20716 Merge branch 'master' into metaconfig 2013-09-28 22:49:50 +02:00
b7f85b8559 Merge branch 'master' into lgpl 2013-09-28 18:43:46 +02:00
70f684e70c tiramisu/option.py:
separate _consistencies (for Option) and _cache_consistencies (for OptionDescription)
  _launch_consistency need index for multi's option
  _cons_not_equal support multi options

tiramisu/value.py:
  Multi._validate support consistency
2013-09-28 17:05:01 +02:00
482dfec7f2 consistancies can have more than one option
add _cons_broadcast
2013-09-27 23:27:08 +02:00
gwen
2490d00935 refactor name only_private 2013-09-27 11:28:23 +02:00
gwen
162ae02df8 refactor (warnings_only) 2013-09-27 09:52:18 +02:00
3073940ca4 can't assign to an OptionDescription 2013-09-26 22:35:12 +02:00
1d2008fd84 error message for ip/broadcast/netmask/network validation 2013-09-26 22:27:39 +02:00
a004f30e34 french translation correction 2013-09-26 22:11:25 +02:00
f4677b9ef9 use warnings instead of a new dictionary 2013-09-26 21:56:06 +02:00
f040d3da61 warning is now a dict 2013-09-26 18:35:20 +02:00
329b9ac349 add _second_level_validation (second's one return only warning almost _validator raise) 2013-09-25 21:10:45 +02:00
4e0f0a5b70 config_error is an exception, raise directly config_error 2013-09-25 10:22:31 +02:00
06baff2f3b add warning ability 2013-09-24 23:19:20 +02:00
a08af2383d comment config 2013-09-23 22:55:54 +02:00
3fc89be40e comment tiramisu/autolib.py + some modification 2013-09-23 22:40:10 +02:00
26e3651848 update french translation 2013-09-23 21:00:45 +02:00
8a7078d3b0 gpl to lgpl 2013-09-22 22:33:09 +02:00
d2f101b7bb didnot getattr a second time in find if not needed 2013-09-22 21:54:07 +02:00
051f1c8774 tiramisu/config.py:
- find byvalue support Multi

tiramisu/value.py:
 - Multi's pop comment
2013-09-22 21:23:12 +02:00
c84d13a1c6 we can serialize Config now 2013-09-22 20:57:52 +02:00
972dff0a1c serialize new callback 2013-09-20 23:47:40 +02:00
ae4df32d0e error if change slave len for default's slave option 2013-09-19 23:02:15 +02:00
28c416dd84 add allow_reserved in IPOption 2013-09-19 21:51:55 +02:00
90ae9aa70d refactore carry_out_calculation + test + documentation 2013-09-19 21:39:41 +02:00
gwen
30ff0fb72b Merge branch 'master' of ssh://git.labs.libre-entreprise.org/gitroot/tiramisu 2013-09-17 14:03:03 +02:00
866364059c dont change anything if config_error 2013-09-17 09:10:08 +02:00
7165f73292 add metaconfig 2013-09-17 09:02:10 +02:00
57f4dd8d3f allow mandatory value (see 9ddf100118 for more details) 2013-09-16 20:51:13 +02:00
gwen
653eb776bf Merge branch 'master' of ssh://git.labs.libre-entreprise.org/gitroot/tiramisu 2013-09-16 15:21:18 +02:00
gwen
ffc9d086f9 double negation in error msg 2013-09-16 15:21:08 +02:00
9ddf100118 when we get an option's value, we need it's values to calculate properties (ie for mandatory's option)
if a disabled option has a callback to an other disabled value, it's raise ConfigError

now only raise if option has no other propertiesError
2013-09-16 15:07:34 +02:00
abbb7a274e update doc 2013-09-14 14:44:50 +02:00
28ea4f0e90 update doc 2013-09-10 21:04:12 +02:00
3dc72c505c support no expire in getcache 2013-09-07 22:37:13 +02:00
632de1cffb comment tiramisu/setting.py 2013-09-07 22:16:50 +02:00
371f094dcb comment tiramisu/setting.py 2013-09-07 21:47:17 +02:00
77c1ccf40b add 'cache' property 2013-09-07 17:25:22 +02:00
f8b0a53c3f cache is always a dictionary in memory 2013-09-07 10:31:39 +02:00
c8876ab184 comment storage 2013-09-06 23:53:19 +02:00
22bfbb9fa4 storage no more in setting.py, code is now in storage/__init__.py 2013-09-06 23:15:36 +02:00
gwen
18fc5db4ac lists in sets 2013-09-06 09:05:19 +02:00
dc688ad644 ro/rw_append/remove are now 'set' type 2013-09-04 09:09:45 +02:00
gwen
02873f2836 Merge branch 'master' of ssh://git.labs.libre-entreprise.org/gitroot/tiramisu 2013-09-04 09:05:25 +02:00
gwen
9983739b2b pep8 line too long 2013-09-04 09:05:12 +02:00
3b733d1b4f support cache consistencies + no consistencies for a symlink + test 2013-09-03 22:41:18 +02:00
gwen
fc9f6ce816 Merge branch 'master' of ssh://git.labs.libre-entreprise.org/gitroot/tiramisu 2013-09-03 11:01:37 +02:00
gwen
f9fde44b3b docstrings 2013-09-03 11:01:07 +02:00
aeeaf6ec14 impl_get_information and impl_set_information are, now, persistent in storage 2013-09-03 10:38:38 +02:00
0212a15387 add __setstate__ to loads from a serialised object 2013-09-02 23:04:37 +02:00
cc3a33ef4f true serialize for _children 2013-09-02 21:29:41 +02:00
84b7ec7b37 update __slots__ for Option/BaseOption 2013-09-02 20:46:51 +02:00
8ccfba1671 factorise Option and OptionDescription init 2013-09-02 20:37:23 +02:00
f106f3ced7 cannot set properties if those properties are in requirement 2013-09-02 19:47:00 +02:00
4636a977cc requirements: calculate all requirements for an option 2013-09-02 17:13:43 +02:00
gwen
5624a69e41 merge 2013-09-02 15:11:38 +02:00
gwen
7dd9394b84 makefile and docstrings 2013-09-02 15:06:55 +02:00
2c1da6d72e an OptionDescription can be serialized 2013-09-02 15:01:49 +02:00
d3ee2acaab can export options 2013-09-01 22:20:11 +02:00
82b375ade5 - add "make build-pot" to build or update translations/tiramisu.pot files
- corrections in error's message in tiramisu/option.py
- update tiramisu.pot
- update fr's translation
2013-08-31 09:54:23 +02:00
5893f8ad72 attributes in Option are now read-only if option set in Config (_name is everytime read-only) 2013-08-30 21:15:55 +02:00
gwen
5efc62af09 docstring setpermissive 2013-08-29 09:32:32 +02:00
8aa4260404 test force_default_on_freeze with multi and correction in Multi() 2013-08-28 22:50:35 +02:00
7f755e0ef8 setpermissive should have opt has option 2013-08-28 22:05:44 +02:00
gwen
fbf05ba5e4 python 3 compatibility
remove __eq__ and __ne__ in Option
2013-08-28 21:13:42 +02:00
776524a22d pep8 2013-08-28 09:18:48 +02:00
397a600be7 pep8 2013-08-28 09:16:12 +02:00
3be005e82e add test test/test_dereference.py + memoryleaks in optiondescription's cache 2013-08-27 21:36:52 +02:00
d75cef9c0f pep8 2013-08-27 17:13:20 +02:00
gwen
a894a5e27b rename API add_owner -> addowner 2013-08-27 16:12:53 +02:00
acd27fb56c huge use of weakrefs to remove memoryleaks due to circular references 2013-08-27 11:39:32 +02:00
36def6533f store session in dictionary storage 2013-08-27 09:46:52 +02:00
fb1eba39ea save storage with get_storage
list_sessions and delete_session is now in setting directly
2013-08-26 21:54:41 +02:00
0bc47b1cf9 ConstError in tiramisu/error.py
storage_type is now unique
rename _const => _NameSpace
can change storage's options in set_storage

storage :
add Setting object in storage
rename enumerate to list_sessions
rename delete to delete_session
auto-create owner when load sqlite3 storage and in getowner
2013-08-26 21:48:42 +02:00
gwen
551b9fb1e3 getting stated documentation 2013-08-26 17:14:14 +02:00
6b9d5aed59 add enumerate and delete method for manage storage 2013-08-25 21:57:11 +02:00
dc2c173b44 revert change in append of Multi object for sqlite3 storage 2013-08-25 20:51:29 +02:00
dcb12dac02 can change storage with set_storage, storage's name is store in storage object and storage is create with get_storage 2013-08-25 20:49:24 +02:00
36ed6f874f add some tests for values
cannot use __setitem__ to set value for an option
in append, len should not greater than master option
2013-08-25 18:06:07 +02:00
f482737a47 add test to known if has a value + some corrections 2013-08-24 23:10:35 +02:00
e4c129efc5 getowner need now an option 2013-08-24 22:32:54 +02:00
4c27cb586d in __setattr__, name should never be object's variable name
remove context in type_ find's option
find_first_context return AttributError if no results
2013-08-24 21:26:10 +02:00
6708fe4522 is not config in other, __neq__ should return True 2013-08-24 18:04:19 +02:00
a7d784ba3e is not config in other, __neq__ should return True 2013-08-24 18:04:11 +02:00
196d270cc9 _calc_requirement is a set, not a tuple 2013-08-24 16:34:08 +02:00
c2b16d2605 add _path in reset for performance + more tests 2013-08-24 16:30:46 +02:00
gwen
0db7ef72a6 automatic API documentation 2013-08-23 11:16:26 +02:00
f8422c03e8 reqpath is get from option, so reqpath ever exists, cannot raise AttributeError 2013-08-22 22:52:29 +02:00
04aa4e6bf1 never same calculated properties has properties (only in cache) 2013-08-22 22:48:09 +02:00
gwen
747d994762 documentation on the requirements and docstring updates 2013-08-22 11:08:26 +02:00
1ddd88fc99 some corrections in sqlite3 storage 2013-08-21 23:21:28 +02:00
b6bb685ca5 key is now always path and change opt by path dictionary storage 2013-08-21 22:21:50 +02:00
707a215a2c pep8 2013-08-21 18:34:32 +02:00
gwen
acca6d5a27 documentation update and docstrings 2013-08-21 17:21:09 +02:00
gwen
7d2449380c documentation and docstring updates 2013-08-21 14:52:48 +02:00
gwen
a431b46fb9 Merge branch 'master' of ssh://git.labs.libre-entreprise.org/gitroot/tiramisu 2013-08-21 11:10:15 +02:00
gwen
defae40a2f documentation update and docstrings 2013-08-21 11:09:11 +02:00
cc569efcc7 pep8 2013-08-20 23:00:20 +02:00
0d5a447eb3 add persistent option for db 2013-08-20 22:45:11 +02:00
d971448d02 pep8 2013-08-20 16:48:19 +02:00
2e8c75a602 merge from val_prop_plugin branch 2013-08-20 16:45:54 +02:00
82b0e26568 merge from val_prop_plugin branch 2013-08-20 16:44:52 +02:00
gwen
5c8bb1f8f9 documentation update 2013-08-20 16:38:06 +02:00
ace7f6f828 merge from master 2013-08-20 16:33:32 +02:00
gwen
564fecc261 pep 8 lines too long 2013-08-20 12:08:02 +02:00
e826f3d1c6 we can personalise storage easily 2013-08-20 09:47:12 +02:00
df7d6759cd add sqlite plugin 2013-08-19 11:01:21 +02:00
f6f709f83d split cache/value/setting in plugin 2013-08-14 23:06:31 +02:00
513722ed57 corrections in tiramisu's setting 2013-07-23 14:24:42 +02:00
e9ffd96a28 update translation 2013-07-18 21:25:07 +02:00
e6c3104681 translation 2013-07-17 23:05:43 +02:00
bc054d75af translation 2013-07-17 23:02:50 +02:00
15ac8c2872 update french translation 2013-07-17 22:30:35 +02:00
8056387f02 return true error message when validation 2013-07-17 20:48:46 +02:00
de44daafeb - can reset directly custom settings for an option: setting[option].reset()
- option properties are now tuple in internal, and change it to set when needed (that coping data)
2013-07-13 10:42:10 +02:00
gwen
a95f19d5f4 default settings 2013-07-12 16:20:34 +02:00
c53d574ac2 can't use RESERVED address in IPOption and NetworkOption 2013-07-11 23:06:26 +02:00
1c951558da add new option's type: PortOption 2013-07-11 23:05:33 +02:00
c06659012b Config: __str__ raise if no str/unicode value 2013-07-03 21:56:31 +02:00
0afb521766 support multi requirement with inverse for same option 2013-07-03 15:04:15 +02:00
gwen
b80bef0f7e string.format with numeric parameters 2013-07-02 15:05:50 +02:00
4b5d9b4229 __str__ method could return unicode object, force to decode in str 2013-07-01 16:49:10 +02:00
b8bfa02e02 Remove 'build_actions' in 'apply_requires', now 'validate_requires_arg' build requires with tuple of tuple
New _requires format:
- requirement (like old format)
- tuple of requirements, each items are a tuple of requirement with same action
2013-07-01 11:55:32 +02:00
9b134c3aa7 requirement are now a dictionary (not anymore a tuple) 2013-06-29 18:41:14 +02:00
e501c6d12d support multi requires with inverse set to True 2013-06-28 11:59:51 +02:00
75f7e7ce5d callback with option in params which is in an hidden optiondescription 2013-06-26 16:26:42 +02:00
32de14b731 validate_requires_arg return requires list 2013-06-26 16:25:02 +02:00
3c0629e6a9 better raise message if try to launch impl_get_information/impl_set_information in uncompatible class 2013-06-14 17:52:57 +02:00
4d15c91383 symlink support for getowner and raise if option in master/slave 2013-06-13 22:06:49 +02:00
c2471320c3 apply_requires: add property if any property raise PropertyError if same_action is False 2013-06-13 14:43:51 +02:00
755b2312c2 allow None in requirement 2013-06-13 12:15:46 +02:00
fd02a954ca add sort, reverse, insert and extend in Multi 2013-06-12 22:48:22 +02:00
9c47eb32d5 ConfigError, not PropertiesOptionError if cannot access to option in carry_out_calculation 2013-06-12 17:07:29 +02:00
0d114001f4 Works callback/multi/master-slave
- in multi, never modify _default value
- _reset slave when _reset master
- if append None in master with callback return not a list, replace None by the value
- list support in slave
2013-06-12 10:22:50 +02:00
b2538f6f0b support of non multi variable 2013-06-11 15:31:20 +02:00
6d1cf308b2 Better support for slave with callback:
- callback must return single value, not a list
- if default value, append slave values with master len
- if not default and append, set default value
2013-06-11 15:12:31 +02:00
gwen
22f0aab0a8 fix i18n 2013-06-10 17:45:03 +02:00
gwen
9cf30d214d raise ConfigError 2013-06-10 17:12:57 +02:00
gwen
1c70a07d7e transitivity in the requirements 2013-06-10 15:19:00 +02:00
2751a2694a RequirementRecursiveError => RequirementError
Properties in "apply_requires" are now transitive (but only if tested property is in properties list)
New requirement option (a boolean), don't touch properties if PropertyError in "apply_requires"
2013-05-31 23:30:00 +02:00
gwen
c6c422f472 docstrings and api 2013-05-23 17:51:50 +02:00
gwen
879a415e75 add docstrings 2013-05-23 14:55:52 +02:00
gwen
0e6032dd88 new api documentation 2013-05-21 18:42:56 +02:00
gwen
480ed190aa Merge branch 'master' of ssh://git.labs.libre-entreprise.org/gitroot/tiramisu 2013-05-21 11:38:02 +02:00
gwen
9acb522791 doc is ready for the new api refactoring 2013-05-21 11:37:39 +02:00
e131fdc5a5 add cfgimpl_get_children for MetaConfig and informations 2013-05-21 11:09:09 +02:00
1d8c248d1b Multi: don't touch slave's value if it's default one's + don't check slave properties (if, for example, disabled for example) 2013-05-21 11:09:09 +02:00
gwen
988bd659b8 refactoring the doc for the 0.55 new API 2013-05-15 17:35:49 +02:00
gwen
89dca8d707 suppress get_consistencies() method 2013-05-14 17:40:42 +02:00
536eb27904 multi, None and validation 2013-05-10 22:34:07 +02:00
gwen
bd489346a9 docstrings 2013-05-10 16:02:27 +02:00
c91e7eff97 if not need, don't validate 2013-05-10 16:00:53 +02:00
fa5d643aee tiramisu/autolib.py: optimpl_ => impl_
tiramisu/option.py: consistency simplication and allow multi
tiramisu/option.py: don't touch cache if force_permissive or force_properties
tiramisu/values.py: set validate paramaters in Multi()
2013-05-10 15:10:06 +02:00
6ffd71a43e DomainnameOption now works with default value 2013-05-10 09:27:54 +02:00
6de65859b4 * config herite from BaseInformation class
* _cfgimpl_ => _impl_
* optimpl_ => impl_
* properties/permissives are now set/frozenset
* validation raise ValueError if not valid, didn't return anything otherwise
* consistencies are now validate in setting and when deleting value
* ip/network with netmask consistency now works
* DomainnameOption now works
* if no validation, don't set cache for value
* symlinkoption: remove path (not used)
2013-05-08 18:14:42 +02:00
1b29793e0f compare option 2013-05-05 21:43:19 +02:00
2d57ed160e work on MetaConfig 2013-05-02 11:34:57 +02:00
9ceaa4b235 tiramisu/i18n.py: pep8 compliants 2013-05-02 11:23:47 +02:00
bcfc0cd41b tiramisu/setting.py: _get_properties and validate_properties are now more easier to read and has best performance 2013-05-02 11:23:04 +02:00
2c5bbb7bc0 Requires need option, not path
Valid requires
2013-04-26 14:40:44 +02:00
509f41e14c missing properties in PropertiesOptionError 2013-04-24 17:40:16 +02:00
f28288fbba In make_dict check PropertyConfigError for OptionDescription
Begin work's on MetaConfig
2013-04-24 11:47:01 +02:00
2e21f13387 force_store_value store value but not in write mode 2013-04-23 16:43:39 +02:00
e8bc84ab33 Ajout des fichiers de traduction et mise à jour de i18n.py
Support du chargement des locales
2013-04-23 16:30:24 +02:00
7cd44d6886 remove an unused callback in test 2013-04-23 11:41:16 +02:00
20fe56e03d tiramisu/values: _empty should not validate with defaultvalue, defaultvalue is already in value 2013-04-23 10:41:47 +02:00
e5de0234c2 don't raise if check_disabled is True 2013-04-22 20:42:54 +02:00
ec88d817ae missing import 2013-04-22 16:48:56 +02:00
1fd5f685de callback must be a function and validator support same paramaters has callback 2013-04-22 16:48:13 +02:00
e883e5b89e remove _setoption in SymLinkOption
objimpl_ => optimpl_
ConflictConfigError => ConflictError
add read_write/read_only/getowner in Config
2013-04-22 09:19:05 +02:00
682d9fe207 add option name's validation and rename Option method with objimpl_ 2013-04-20 21:58:52 +02:00
d4ef47759e Manipulate properties is now more convenient:
c.cfgimpl_get_settings().has_property('hidden') => 'hidden' in c.cfgimpl_get_settings()
c.cfgimpl_get_settings().has_property('hidden', option1) => 'frozen' in c.cfgimpl_get_settings()[opt]

c.cfgimpl_get_settings().get_properties(option1) => c.cfgimpl_get_settings()[option1]
c.cfgimpl_get_settings().get_properties(option1) => c.cfgimpl_get_settings()[option1]

c.cfgimpl_get_settings().add_property('hidden', option1) => c.cfgimpl_get_settings()[optiont1].append('hidden')
c.cfgimpl_get_settings().del_property('hidden', option1) => c.cfgimpl_get_settings()[optiont1].remove('hidden')

c.cfgimpl_get_settings().enable_property('hidden') => c.cfgimpl_get_settings().append('hidden')
c.cfgimpl_get_settings().disable_property('hidden') => c.cfgimpl_get_settings().remove('hidden')
2013-04-20 17:30:05 +02:00
54fe8d0f4b cache for properties is now in get_properties and not for validate_properties 2013-04-20 11:25:14 +02:00
a11768ef43 remove expired cache with config.cfgimpl_reset_cache(True) 2013-04-19 22:42:33 +02:00
d7b5d9dc16 add SlaveError for slave's length 2013-04-19 20:23:34 +02:00
410add6a2a add SlaveError for slave's length 2013-04-19 20:10:55 +02:00
e08bd93cd8 all multi gestion is now in Multi 2013-04-18 23:06:14 +02:00
324c3d2cf6 * to "reset" a value, now you just have to delete it
config.unwrap_from_path("string").reset(config) => del(config.string)
* add cache for value/setting to 5 secds
to "reset" cache just do: config.cfgimpl_clean_cache()
* can desactivate cache by removing "expire" property
2013-04-18 20:26:40 +02:00
d5e1cb6576 pass force_properties to value's _setitem and remove config's setoption 2013-04-17 23:19:53 +02:00
5e67522f91 _empty is u'' for UnicodeOption 2013-04-17 22:06:10 +02:00
eea96cc3d1 MultiTypeError => ValueError 2013-04-17 21:57:06 +02:00
80438b1495 Rename AmbigousOptionError as ConflictOptionError 2013-04-17 21:50:31 +02:00
3170237c8e properties validation not in setting and now launch when modify multi 2013-04-17 21:33:34 +02:00
656b751995 mandatory is a true property (no more MandatoryError) + tests 2013-04-16 22:44:16 +02:00
6097f3af84 only catch PropertiesOptionError 2013-04-16 12:04:20 +02:00
16801ad1b2 SubConfig: first argument must be a OD 2013-04-16 11:51:48 +02:00
90999585fa auto_store_value => force_store_value 2013-04-16 11:30:02 +02:00
447c175b6a Add "force_store_value" property. If set, store, for example, calculated value as owner values.
So calculated value are calculate only one time.
2013-04-16 09:45:42 +02:00
1f0bb88bc1 add cons_lower + DomainnameOption 2013-04-16 09:34:00 +02:00
9357b342c1 review exception 2013-04-14 12:01:32 +02:00
fbcbbfbd2b consistencies now a list 2013-04-14 10:14:06 +02:00
9644dd3661 add gettext support 2013-04-13 23:09:05 +02:00
9c2dcc164c attribute in Option now starts with '_'
add ValidateError
add consistancies in Option
remove byattr in find
2013-04-13 22:50:55 +02:00
26568dc45a Values validate now value 2013-04-11 11:30:58 +02:00
0c5ab9df18 don't launch apply_requires more than needed 2013-04-08 16:12:23 +02:00
67e67a5020 NoValueReturn is not needed now + apply_requires is now in settings 2013-04-08 16:05:56 +02:00
d8b68fa1ec suppress _cfgimpl_parent and _cfgimpl_get_path() from SubConfig 2013-04-05 16:59:48 +02:00
88ea962d82 tiramisu/config.py: _cfgimpl_subconfigs is not used 2013-04-05 12:31:50 +02:00
d100d66548 tiramisu/config.py can specify return type for find ('option', 'value', 'path') and remove get
user need replace config.get(value) by config.find(byname="value", type_='value')
2013-04-05 12:20:33 +02:00
c918191d21 permissives are for a specified option not config 2013-04-04 15:14:16 +02:00
9006dca09f set permissive to cfgimpl_get_home_by_path 2013-04-04 12:16:18 +02:00
e9902d8ce2 rewrite make_dict 2013-04-04 11:24:00 +02:00
6105191d9c tiramisu/value.py : self.opt => opt + disable permissive in read_write mode 2013-04-03 17:05:41 +02:00
e6f00948f3 optimisations and all is properties 2013-04-03 12:20:26 +02:00
gwen
8181d1b596 build cache builds correctly now 2013-03-27 17:01:20 +01:00
201f9d6db4 remise en fonction des self._cfgimpl_slots 2013-03-27 16:41:22 +01:00
d00153787d Le cache des paths est dans l'OptionDescription
Utilisation des slots pour la Config

Il faut 566Mo de mémoire pour charger 50 variantes de 100 serveurs chacuns (5000 serveurs en tout).

ref #5111
2013-03-27 16:17:45 +01:00
899f864f8d works on performante 2013-03-26 10:29:49 +01:00
4f3db9cbc6 support break in iterator 2013-03-25 14:21:30 +01:00
39c8e2eb0b add import and name => opt._name 2013-03-25 11:45:21 +01:00
f6a14e3223 add UnicodeOption 2013-03-20 12:37:27 +01:00
087f7e3a75 cfgimpl_permissive is not the permissive param 2013-03-14 17:51:51 +01:00
9e81ae4737 get_home_by_path is a public method 2013-03-14 16:07:26 +01:00
15beeda0f0 add permissive in config 2013-03-14 11:31:44 +01:00
783e982c9b informations attribute finally works 2013-03-13 11:29:29 +01:00
e1357fd5c5 adds information attribute to an option 2013-03-12 17:45:28 +01:00
729feb3239 adds information attribute to an option 2013-03-12 16:54:39 +01:00
gwen
11ad037af9 iter on all objects 2013-03-07 11:02:18 +01:00
9b3eb33d27 generate correct len for slave if no value 2013-03-06 17:17:33 +01:00
gwen
c26b0ca12b Merge branch 'master' of ssh://git.labs.libre-entreprise.org/gitroot/tiramisu 2013-03-06 09:34:07 +01:00
gwen
4660f58608 valid name accepts only str type 2013-03-06 09:22:56 +01:00
gwen
e360a07a21 BaseType refactoring 2013-03-01 13:10:52 +01:00
gwen
df3753c36b finally a getvalue without a getattr 2013-02-27 11:09:13 +01:00
gwen
c40d33fec3 type shall not be a list 2013-02-27 08:50:41 +01:00
gwen
1f1e5e5d26 type shall not be a list 2013-02-26 17:04:41 +01:00
gwen
e515ec145d type shall not be a list 2013-02-26 16:58:44 +01:00
gwen
151bc83ba5 previous value api 2013-02-26 14:56:15 +01:00
gwen
762b0e9c69 is_empty 2013-02-26 14:31:45 +01:00
gwen
8be48e5eba pep8 2013-02-25 16:24:30 +01:00
gwen
eb632c002d option names shall be valid names 2013-02-25 16:06:10 +01:00
gwen
a02cb26d5f masterlen > instead of != 2013-02-25 15:52:10 +01:00
gwen
ea7d297c9b private method _get_multitype() 2013-02-25 15:12:09 +01:00
gwen
77633c84ce private method _get_multitype() 2013-02-25 14:27:12 +01:00
gwen
7b4f3b5d36 option's name shall not have an api's method name 2013-02-25 11:33:20 +01:00
gwen
8f4efe6b00 add masters/slaves in the Values() 2013-02-22 11:09:17 +01:00
gwen
e6d5d349c8 refactoring values 2013-02-21 17:07:00 +01:00
gwen
b69ecbd2eb update of the doc 2013-02-19 11:24:17 +01:00
gwen
a8e6bac87f refactoring, the values are in an OptionValues object 2013-02-08 11:50:22 +01:00
gwen
9259a6e3f7 values are in value objects now 2013-02-07 16:20:21 +01:00
gwen
29914051e0 master groups that have multis 2013-02-06 17:19:56 +01:00
gwen
a404c4c992 masters shall have the same names as groups 2013-02-06 16:21:30 +01:00
gwen
6a3b7102b5 adds a freeze_everything possibility 2013-02-06 14:59:24 +01:00
gwen
d00a623fc1 validator set to false for read_write in setting 2013-02-06 14:34:12 +01:00