Commit Graph

345 Commits

Author SHA1 Message Date
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
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
9f3d676280 reduce memory usage 2014-10-25 22:11:31 +02:00
71f8926fca better support for sqlalchemy storage 2014-07-06 15:31:57 +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
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
6d8137160c 'getattr' in optiondescription can return a bound method 2014-04-15 21:48:31 +02:00
7c8164090a uncomment more test 2014-04-14 23:00:37 +02:00
9bec52273a we can pickle object 2014-04-14 22:53:40 +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
299e51e806 start works on storage 2014-04-12 22:47:52 +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
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
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
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
f7d31bfa92 Merge branch 'master' into force-cache
Conflicts:
	translations/fr/tiramisu.po
	translations/tiramisu.pot
2014-03-15 10:09:19 +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
5f46763696 add test for consistency with callback 2014-03-12 16:44:48 +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
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
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
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
0aeb64731b comment state test 2014-02-06 22:25:04 +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
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
ced260046c test for multi 2014-02-02 18:21:09 +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
2f40216fad Merge branch 'master' into orm 2014-02-01 17:25:39 +01:00
71b235551e add tests for find() 2014-02-01 17:25:31 +01:00
cddeef0990 Merge branch 'master' into orm 2014-02-01 16:49:29 +01:00
f48f3e7544 add tests for find() 2014-02-01 16:49:16 +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
7c8049a8d0 Merge branch 'master' into orm 2014-01-27 23:28:43 +01:00
a1dd2cfce7 require works well in sqlalchemy storage 2014-01-27 17:16:05 +01:00
gwen
9deb67f887 warning and error messages not translated in the tests 2014-01-27 14:55:53 +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
3b3e5216fe cache 2014-01-25 10:15:25 +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
cde04d654a Merge branch 'master' into orm
Conflicts:
	tiramisu/setting.py
2014-01-09 20:32:17 +01:00
gwen
3c36e05d82 adds test for an API 2014-01-06 14:40:29 +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
c58de18b62 add more tests 2013-12-09 18:56:29 +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
6e4f19eebe more tests 2013-12-09 15:43:45 +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
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
eb3327cd75 correction in allow_without_dot + test 2013-10-01 10:13:17 +02:00
6902ad4f18 some extra tests for filename 2013-10-01 08:23:10 +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
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
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
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
e63dbf308d more tests for warnings 2013-09-26 09:31:51 +02:00
329b9ac349 add _second_level_validation (second's one return only warning almost _validator raise) 2013-09-25 21:10:45 +02:00
06baff2f3b add warning ability 2013-09-24 23:19:20 +02:00
3fc89be40e comment tiramisu/autolib.py + some modification 2013-09-23 22:40:10 +02:00
ff7714d8d3 add find test value in a multi's option 2013-09-22 21:31:37 +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
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
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
3dc72c505c support no expire in getcache 2013-09-07 22:37:13 +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
22bfbb9fa4 storage no more in setting.py, code is now in storage/__init__.py 2013-09-06 23:15:36 +02:00
3b733d1b4f support cache consistencies + no consistencies for a symlink + test 2013-09-03 22:41:18 +02:00
aeeaf6ec14 impl_get_information and impl_set_information are, now, persistent in storage 2013-09-03 10:38:38 +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
52a6705fbf new logo for the tiramisu project 2013-09-02 16:27:22 +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
c01f14920d test more sloted options 2013-08-30 09:40:28 +02:00
eb62d0c4a4 add test for impl_get_path_by_opt and impl_get_opt_by_path 2013-08-29 09:29:28 +02:00
8aa4260404 test force_default_on_freeze with multi and correction in Multi() 2013-08-28 22:50:35 +02:00
8c24903dfb order in properties can change 2013-08-28 21:23:42 +02:00
gwen
fbf05ba5e4 python 3 compatibility
remove __eq__ and __ne__ in Option
2013-08-28 21:13:42 +02:00
71a8171c52 add tests for persistent mode 2013-08-27 22:08:35 +02:00
3be005e82e add test test/test_dereference.py + memoryleaks in optiondescription's cache 2013-08-27 21:36:52 +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
gwen
551b9fb1e3 getting stated documentation 2013-08-26 17:14:14 +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
e6a183c00d test get_modified_values 2013-08-24 22:54:02 +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
c2b16d2605 add _path in reset for performance + more tests 2013-08-24 16:30:46 +02:00
62553aba1f test invalid owner in setowner 2013-08-23 09:29:42 +02:00
ac62931525 add test for recursive path in requirement 2013-08-22 22:57:32 +02:00
04aa4e6bf1 never same calculated properties has properties (only in cache) 2013-08-22 22:48:09 +02:00
gwen
3d67e35447 documentation on the tests 2013-08-22 12:17:10 +02:00
b6bb685ca5 key is now always path and change opt by path dictionary storage 2013-08-21 22:21:50 +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
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
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