소스 검색

Merge branch 'newlodel' of git.labocleo.org:lodel2 into newlodel

Yann Weber 8 년 전
부모
커밋
4f542e0866

+ 4
- 2
lodel/settings/settings_loader.py 파일 보기

@@ -28,8 +28,10 @@ class SettingsLoader(object):
28 28
         l_dir = glob.glob(self.__conf_path+'/*.ini')  
29 29
 
30 30
         for f_ini in l_dir:  
31
-            config = configparser.ConfigParser(default_section = 'lodel2')
31
+            #To avoid the DEFAULT section whose values are found in all sections, we have to give it an unsual name
32
+            config = configparser.ConfigParser(default_section = 'lodel2_default_passaway_tip',interpolation=None)
32 33
             config.read(f_ini)
34
+
33 35
             for sect in config:
34 36
                 if sect in conf:
35 37
                     for param in config[sect]:
@@ -42,7 +44,7 @@ class SettingsLoader(object):
42 44
                     opts={}
43 45
                     for key in config[sect]:
44 46
                         opts[key] = config[sect].get(key)
45
-                        if sect != 'DEFAULT': self.__conf_sv[sect + ':' + key]=f_ini
47
+                        if sect != 'lodel2_default_passaway_tip': self.__conf_sv[sect + ':' + key]=f_ini
46 48
                     conf.update({sect: opts})
47 49
         os.close(dir_conf)
48 50
         return conf

+ 0
- 6
tests/settings/conf.d/b.ini 파일 보기

@@ -1,6 +0,0 @@
1
-[B]
2
-ab=art
3
-bb=bj,kl,mn
4
-cb=tatat
5
-[A]
6
-fhui=njl

+ 0
- 8
tests/settings/conf_raise.d/a.ini 파일 보기

@@ -1,8 +0,0 @@
1
-[A]
2
-a=a1
3
-b=b1,b2,b3
4
-c=toto
5
-[C]
6
-ca=a2
7
-cb=b4,b2,b3
8
-cc=titi

+ 8
- 0
tests/settings/settings_examples/conf.d/a.ini 파일 보기

@@ -0,0 +1,8 @@
1
+[lodel2.A]
2
+a=a1
3
+b=b1,b2,b3
4
+c=toto
5
+[lodel2.A.e]
6
+titi=tata
7
+[lodel2.C]
8
+a=test

+ 3
- 0
tests/settings/settings_examples/conf.d/b.ini 파일 보기

@@ -0,0 +1,3 @@
1
+[lodel2.A]
2
+fhui=njl
3
+

+ 2
- 0
tests/settings/settings_examples/conf.d/c.ini 파일 보기

@@ -0,0 +1,2 @@
1
+[lodel2.A.e]
2
+a=ft

+ 8
- 0
tests/settings/settings_examples/conf.d/d.ini 파일 보기

@@ -0,0 +1,8 @@
1
+[lodel2.C]
2
+ca=a2
3
+cb=b4,b2,b3
4
+cc=titi
5
+[lodel2.B]
6
+ab=art
7
+bb=bj,kl,mn
8
+cb=tatat

tests/settings/conf.d/a.ini → tests/settings/settings_examples/conf_raise.d/a.ini 파일 보기


tests/settings/conf_raise.d/b.ini → tests/settings/settings_examples/conf_raise.d/b.ini 파일 보기


+ 16
- 14
tests/settings/test_settings_loader.py 파일 보기

@@ -8,34 +8,36 @@ from lodel.settings.settings_loader import SettingsLoader
8 8
 #A dummy validator that only returns the value
9 9
 def dummy_validator(value): return value
10 10
 #A dummy validator that always fails
11
-def dummy_validator_fails(value):  raise ValueError("Fake validaion error") 
11
+def dummy_validator_fails(value):  raise ValueError("Fake validation error") 
12 12
 
13 13
 class SettingsLoaderTestCase(unittest.TestCase):
14 14
 
15 15
     def test_merge_getsection(self):
16 16
         """Tests merge and getSection functions """
17
-        settings = SettingsLoader('tests/settings/conf.d')
17
+        settings = SettingsLoader('tests/settings/settings_examples/conf.d')
18 18
         def maFonction(a):
19 19
             return a
20
-        e=settings.getoption('A','a',maFonction)
20
+        e=settings.getoption('lodel2.A','a',maFonction)
21 21
         self.assertEqual(e,'a1')
22
-        f=settings.getoption('B','bb',maFonction)
22
+        f=settings.getoption('lodel2.B','bb',maFonction)
23 23
         self.assertEqual(f,"bj,kl,mn")
24 24
         g=settings.getremains()
25 25
         self.assertIsNotNone(g)
26
-        e=settings.getoption('A','b',maFonction)
27
-        e=settings.getoption('A','c',maFonction)
28
-        e=settings.getoption('A','fhui',maFonction)
29
-        f=settings.getoption('B','ab',maFonction)
30
-        f=settings.getoption('B','cb',maFonction)
31
-        f=settings.getoption('C','cb',maFonction)
32
-        f=settings.getoption('C','ca',maFonction)
33
-        f=settings.getoption('C','cc',maFonction)
34
-        f=settings.getoption('C','a',maFonction)
26
+        e=settings.getoption('lodel2.A','b',maFonction)
27
+        e=settings.getoption('lodel2.A','c',maFonction)
28
+        e=settings.getoption('lodel2.A','fhui',maFonction)
29
+        f=settings.getoption('lodel2.B','ab',maFonction)
30
+        f=settings.getoption('lodel2.B','cb',maFonction)
31
+        f=settings.getoption('lodel2.C','cb',maFonction)
32
+        f=settings.getoption('lodel2.C','ca',maFonction)
33
+        f=settings.getoption('lodel2.C','cc',maFonction)
34
+        f=settings.getoption('lodel2.C','a',maFonction)
35
+        f=settings.getoption('lodel2.A.e','a',maFonction)
36
+        f=settings.getoption('lodel2.A.e','titi',maFonction)
35 37
         g=settings.getremains()
36 38
         self.assertEqual(g,[])
37 39
         with self.assertRaises(SettingsError):
38
-            loader = SettingsLoader('tests/settings/conf_raise.d')
40
+            loader = SettingsLoader('tests/settings/settings_examples/conf_raise.d')
39 41
     
40 42
     def test_merge(self):
41 43
         """ Test merge of multiple configuration files """

Loading…
취소
저장