server/test/unittest_rqlannotation.py
branchtls-sprint
changeset 1802 d628defebc17
parent 1398 5fe84a5f7035
child 1977 606923dff11b
--- a/server/test/unittest_rqlannotation.py	Thu May 14 10:24:56 2009 +0200
+++ b/server/test/unittest_rqlannotation.py	Thu May 14 11:38:40 2009 +0200
@@ -9,15 +9,15 @@
 
 class SQLGenAnnotatorTC(BaseQuerierTC):
     repo = repo
-    
+
     def get_max_eid(self):
         # no need for cleanup here
         return None
     def cleanup(self):
         # no need for cleanup here
         pass
-                
-    def test_0_1(self):        
+
+    def test_0_1(self):
         rqlst = self._prepare('Any SEN,RN,OEN WHERE X from_entity SE, SE eid 44, X relation_type R, R eid 139, X to_entity OE, OE eid 42, R name RN, SE name SEN, OE name OEN')
         self.assertEquals(rqlst.defined_vars['SE']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['OE']._q_invariant, False)
@@ -25,13 +25,13 @@
         self.assertEquals(rqlst.defined_vars['SE'].stinfo['attrvar'], None)
         self.assertEquals(rqlst.defined_vars['OE'].stinfo['attrvar'], None)
         self.assertEquals(rqlst.defined_vars['R'].stinfo['attrvar'], None)
-        
-    def test_0_2(self):        
+
+    def test_0_2(self):
         rqlst = self._prepare('Any O WHERE NOT S ecrit_par O, S eid 1, S inline1 P, O inline2 P')
         self.assertEquals(rqlst.defined_vars['P']._q_invariant, True)
         self.assertEquals(rqlst.defined_vars['O'].stinfo['attrvar'], None)
 
-    def test_0_4(self):        
+    def test_0_4(self):
         rqlst = self._prepare('Any A,B,C WHERE A eid 12,A comment B, A ?wf_info_for C')
         self.assertEquals(rqlst.defined_vars['A']._q_invariant, False)
         self.assert_(rqlst.defined_vars['B'].stinfo['attrvar'])
@@ -40,28 +40,28 @@
                                       {'A': 'TrInfo', 'B': 'String', 'C': 'CWUser'},
                                       {'A': 'TrInfo', 'B': 'String', 'C': 'Note'}])
 
-    def test_0_5(self):        
+    def test_0_5(self):
         rqlst = self._prepare('Any P WHERE N ecrit_par P, N eid 0')
         self.assertEquals(rqlst.defined_vars['N']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['P']._q_invariant, True)
 
-    def test_0_6(self):        
+    def test_0_6(self):
         rqlst = self._prepare('Any P WHERE NOT N ecrit_par P, N eid 512')
         self.assertEquals(rqlst.defined_vars['P']._q_invariant, False)
 
-    def test_0_7(self):        
+    def test_0_7(self):
         rqlst = self._prepare('Personne X,Y where X nom NX, Y nom NX, X eid XE, not Y eid XE')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False)
         self.assert_(rqlst.defined_vars['XE'].stinfo['attrvar'])
 
-    def test_0_8(self):        
+    def test_0_8(self):
         rqlst = self._prepare('Any P WHERE X eid 0, NOT X connait P')
         self.assertEquals(rqlst.defined_vars['P']._q_invariant, False)
         #self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
         self.assertEquals(len(rqlst.solutions), 1, rqlst.solutions)
 
-    def test_0_10(self):        
+    def test_0_10(self):
         rqlst = self._prepare('Any X WHERE X concerne Y, Y is Note')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
         self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False)
@@ -71,78 +71,78 @@
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['Y']._q_invariant, True)
 
-    def test_0_12(self):        
+    def test_0_12(self):
         rqlst = self._prepare('Personne P WHERE P concerne A, A concerne S, S nom "Logilab"')
         self.assertEquals(rqlst.defined_vars['P']._q_invariant, True)
         self.assertEquals(rqlst.defined_vars['A']._q_invariant, True)
         self.assertEquals(rqlst.defined_vars['S']._q_invariant, False)
-        
+
     def test_1_0(self):
         rqlst = self._prepare('Any X,Y WHERE X created_by Y, X eid 5, NOT Y eid 6')
         self.assertEquals(rqlst.defined_vars['Y']._q_invariant, True)
-                
+
     def test_1_1(self):
         rqlst = self._prepare('Any X,Y WHERE X created_by Y, X eid 5, NOT Y eid IN (6,7)')
         self.assertEquals(rqlst.defined_vars['Y']._q_invariant, True)
-                
+
     def test_2(self):
         rqlst = self._prepare('Any X WHERE X identity Y, Y eid 1')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
-        
+
     def test_7(self):
         rqlst = self._prepare('Personne X,Y where X nom NX, Y nom NX, X eid XE, not Y eid XE')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False)
-        
+
     def test_optional_inlined(self):
         rqlst = self._prepare('Any X,S where X from_state S?')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['S']._q_invariant, True)
-                
+
     def test_optional_inlined_2(self):
         rqlst = self._prepare('Any N,A WHERE N? inline1 A')
         self.assertEquals(rqlst.defined_vars['N']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['A']._q_invariant, False)
-        
+
     def test_optional_1(self):
         rqlst = self._prepare('Any X,S WHERE X travaille S?')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['S']._q_invariant, True)
-        
+
     def test_greater_eid(self):
         rqlst = self._prepare('Any X WHERE X eid > 5')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
-        
+
     def test_greater_eid_typed(self):
         rqlst = self._prepare('Any X WHERE X eid > 5, X is Note')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
-        
+
     def test_max_eid(self):
         rqlst = self._prepare('Any MAX(X)')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
-        
+
     def test_max_eid_typed(self):
         rqlst = self._prepare('Any MAX(X) WHERE X is Note')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
-        
+
     def test_all_entities(self):
         rqlst = self._prepare('Any X')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
-        
+
     def test_all_typed_entity(self):
         rqlst = self._prepare('Any X WHERE X is Note')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
-        
+
     def test_has_text_1(self):
         rqlst = self._prepare('Any X WHERE X has_text "toto tata"')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
         self.assertEquals(rqlst.defined_vars['X'].stinfo['principal'].r_type, 'has_text')
-        
+
     def test_has_text_2(self):
         rqlst = self._prepare('Any X WHERE X is Personne, X has_text "coucou"')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
         self.assertEquals(rqlst.defined_vars['X'].stinfo['principal'].r_type, 'has_text')
-        
+
     def test_not_relation_1(self):
         # P can't be invariant since deambiguification caused by "NOT X require_permission P"
         # is not considered by generated sql (NOT EXISTS(...))
@@ -150,31 +150,31 @@
         self.assertEquals(rqlst.defined_vars['P']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['G']._q_invariant, True)
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
-        
+
     def test_not_relation_2(self):
         rqlst = self._prepare('TrInfo X WHERE X eid 2, NOT X from_state Y, Y is State')
         self.assertEquals(rqlst.defined_vars['Y']._q_invariant, True)
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
-                
+
     def test_not_relation_3(self):
         rqlst = self._prepare('Any X, Y WHERE X eid 1, Y eid in (2, 3)')
         self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False)
-                
+
     def test_not_relation_4_1(self):
         rqlst = self._prepare('Note X WHERE NOT Y evaluee X')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['Y']._q_invariant, True)
-        
+
     def test_not_relation_4_2(self):
         rqlst = self._prepare('Any X WHERE NOT Y evaluee X')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['Y']._q_invariant, True)
-        
+
     def test_not_relation_4_3(self):
         rqlst = self._prepare('Any Y WHERE NOT Y evaluee X')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
         self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False)
-        
+
     def test_not_relation_4_4(self):
         rqlst = self._prepare('Any X WHERE NOT Y evaluee X, Y is CWUser')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
@@ -184,7 +184,7 @@
         rqlst = self._prepare('Any X WHERE NOT Y evaluee X, Y eid %s, X is Note' % self.ueid)
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
         self.assertEquals(rqlst.solutions, [{'X': 'Note'}])
-        
+
     def test_not_relation_5_1(self):
         rqlst = self._prepare('Any X,Y WHERE X name "CWGroup", Y eid IN(1, 2, 3), NOT X read_permission Y')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
@@ -201,64 +201,64 @@
         self.assertEquals(rqlst.defined_vars['A']._q_invariant, True)
 
     def test_not_relation_7(self):
-        rqlst = self._prepare('Any K,V WHERE P is CWProperty, P pkey K, P value V, NOT P for_user U') 
+        rqlst = self._prepare('Any K,V WHERE P is CWProperty, P pkey K, P value V, NOT P for_user U')
         self.assertEquals(rqlst.defined_vars['P']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['U']._q_invariant, True)
-       
-    def test_exists_1(self):        
+
+    def test_exists_1(self):
         rqlst = self._prepare('Any U WHERE U eid IN (1,2), EXISTS(X owned_by U)')
         self.assertEquals(rqlst.defined_vars['U']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
-       
-    def test_exists_2(self):        
+
+    def test_exists_2(self):
         rqlst = self._prepare('Any U WHERE EXISTS(U eid IN (1,2), X owned_by U)')
         self.assertEquals(rqlst.defined_vars['U']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
 
-    def test_exists_3(self):        
+    def test_exists_3(self):
         rqlst = self._prepare('Any U WHERE EXISTS(X owned_by U, X bookmarked_by U)')
         self.assertEquals(rqlst.defined_vars['U']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
-        
+
     def test_exists_4(self):
         rqlst = self._prepare('Any X,Y WHERE X name "CWGroup", Y eid IN(1, 2, 3), EXISTS(X read_permission Y)')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False)
-        
+
     def test_exists_5(self):
         rqlst = self._prepare('DISTINCT Any X,Y WHERE X name "CWGroup", Y eid IN(1, 2, 3), EXISTS(X read_permission Y)')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['Y']._q_invariant, True)
 
-    def test_not_exists_1(self):        
+    def test_not_exists_1(self):
         rqlst = self._prepare('Any U WHERE NOT EXISTS(X owned_by U, X bookmarked_by U)')
         self.assertEquals(rqlst.defined_vars['U']._q_invariant, False)
-        self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)        
+        self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
 
-    def test_not_exists_2(self):        
+    def test_not_exists_2(self):
         rqlst = self._prepare('Any X,Y WHERE X name "CWGroup", Y eid IN(1, 2, 3), NOT EXISTS(X read_permission Y)')
         self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False)
 
-    def test_not_exists_distinct_1(self):        
+    def test_not_exists_distinct_1(self):
         rqlst = self._prepare('DISTINCT Any X,Y WHERE X name "CWGroup", Y eid IN(1, 2, 3), NOT EXISTS(X read_permission Y)')
         self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False)
-        
-    def test_or_1(self):        
+
+    def test_or_1(self):
         rqlst = self._prepare('Any X WHERE X concerne B OR C concerne X, B eid 12, C eid 13')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, False)
 
-    def test_or_2(self):        
+    def test_or_2(self):
         rqlst = self._prepare('Any X WHERE X created_by U, X concerne B OR C concerne X, B eid 12, C eid 13')
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
-        self.assertEquals(rqlst.defined_vars['U']._q_invariant, True) 
+        self.assertEquals(rqlst.defined_vars['U']._q_invariant, True)
         self.assertEquals(rqlst.defined_vars['X'].stinfo['principal'].r_type, 'created_by')
 
-    def test_or_3(self):        
+    def test_or_3(self):
         rqlst = self._prepare('Any N WHERE A evaluee N or EXISTS(N todo_by U)')
         self.assertEquals(rqlst.defined_vars['N']._q_invariant, False)
-        self.assertEquals(rqlst.defined_vars['A']._q_invariant, True) 
-        self.assertEquals(rqlst.defined_vars['U']._q_invariant, True) 
-        
+        self.assertEquals(rqlst.defined_vars['A']._q_invariant, True)
+        self.assertEquals(rqlst.defined_vars['U']._q_invariant, True)
+
     def test_or_exists_1(self):
         # query generated by security rewriting
         rqlst = self._prepare('DISTINCT Any A,S WHERE A is Affaire, S nom "chouette", S is IN(Division, Societe, SubDivision),'
@@ -270,13 +270,13 @@
         self.assertEquals(rqlst.defined_vars['A']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['S']._q_invariant, False)
 
-    def test_or_exists_2(self):        
+    def test_or_exists_2(self):
         rqlst = self._prepare('Any U WHERE EXISTS(U in_group G, G name "managers") OR EXISTS(X owned_by U, X bookmarked_by U)')
         self.assertEquals(rqlst.defined_vars['U']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['G']._q_invariant, False)
         self.assertEquals(rqlst.defined_vars['X']._q_invariant, True)
-        
-    def test_or_exists_3(self):        
+
+    def test_or_exists_3(self):
         rqlst = self._prepare('Any COUNT(S),CS GROUPBY CS ORDERBY 1 DESC LIMIT 10 '
                               'WHERE C is Societe, S concerne C, C nom CS, '
                               '(EXISTS(S owned_by 1)) OR (EXISTS(S documented_by N, N title "published"))')
@@ -286,7 +286,7 @@
                               '(EXISTS(S owned_by 1)) OR (EXISTS(S documented_by N, N title "published"))')
         self.assertEquals(rqlst.defined_vars['S']._q_invariant, True)
 
-    def test_nonregr_ambiguity(self):        
+    def test_nonregr_ambiguity(self):
         rqlst = self._prepare('Note N WHERE N attachment F')
         # N may be an image as well, not invariant
         self.assertEquals(rqlst.defined_vars['N']._q_invariant, False)