|
1 # -*- coding: iso-8859-1 -*- |
|
2 """unit tests for modules cubicweb.server.rqlannotation |
|
3 """ |
|
4 |
|
5 from cubicweb.devtools import init_test_database |
|
6 from cubicweb.devtools.repotest import BaseQuerierTC |
|
7 |
|
8 repo, cnx = init_test_database('sqlite') |
|
9 |
|
10 class SQLGenAnnotatorTC(BaseQuerierTC): |
|
11 repo = repo |
|
12 |
|
13 def get_max_eid(self): |
|
14 # no need for cleanup here |
|
15 return None |
|
16 def cleanup(self): |
|
17 # no need for cleanup here |
|
18 pass |
|
19 |
|
20 def test_0_1(self): |
|
21 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') |
|
22 self.assertEquals(rqlst.defined_vars['SE']._q_invariant, False) |
|
23 self.assertEquals(rqlst.defined_vars['OE']._q_invariant, False) |
|
24 self.assertEquals(rqlst.defined_vars['R']._q_invariant, False) |
|
25 self.assertEquals(rqlst.defined_vars['SE'].stinfo['attrvar'], None) |
|
26 self.assertEquals(rqlst.defined_vars['OE'].stinfo['attrvar'], None) |
|
27 self.assertEquals(rqlst.defined_vars['R'].stinfo['attrvar'], None) |
|
28 |
|
29 def test_0_2(self): |
|
30 rqlst = self._prepare('Any O WHERE NOT S ecrit_par O, S eid 1, S inline1 P, O inline2 P') |
|
31 self.assertEquals(rqlst.defined_vars['P']._q_invariant, True) |
|
32 self.assertEquals(rqlst.defined_vars['O'].stinfo['attrvar'], None) |
|
33 |
|
34 def test_0_4(self): |
|
35 rqlst = self._prepare('Any A,B,C WHERE A eid 12,A comment B, A ?wf_info_for C') |
|
36 self.assertEquals(rqlst.defined_vars['A']._q_invariant, False) |
|
37 self.assert_(rqlst.defined_vars['B'].stinfo['attrvar']) |
|
38 self.assertEquals(rqlst.defined_vars['C']._q_invariant, False) |
|
39 self.assertEquals(rqlst.solutions, [{'A': 'TrInfo', 'B': 'String', 'C': 'Affaire'}, |
|
40 {'A': 'TrInfo', 'B': 'String', 'C': 'EUser'}, |
|
41 {'A': 'TrInfo', 'B': 'String', 'C': 'Note'}]) |
|
42 |
|
43 def test_0_5(self): |
|
44 rqlst = self._prepare('Any P WHERE N ecrit_par P, N eid 0') |
|
45 self.assertEquals(rqlst.defined_vars['N']._q_invariant, False) |
|
46 self.assertEquals(rqlst.defined_vars['P']._q_invariant, True) |
|
47 |
|
48 def test_0_6(self): |
|
49 rqlst = self._prepare('Any P WHERE NOT N ecrit_par P, N eid 512') |
|
50 self.assertEquals(rqlst.defined_vars['P']._q_invariant, False) |
|
51 |
|
52 def test_0_7(self): |
|
53 rqlst = self._prepare('Personne X,Y where X nom NX, Y nom NX, X eid XE, not Y eid XE') |
|
54 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
55 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False) |
|
56 self.assert_(rqlst.defined_vars['XE'].stinfo['attrvar']) |
|
57 |
|
58 def test_0_8(self): |
|
59 rqlst = self._prepare('Any P WHERE X eid 0, NOT X connait P') |
|
60 self.assertEquals(rqlst.defined_vars['P']._q_invariant, False) |
|
61 #self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
62 self.assertEquals(len(rqlst.solutions), 1, rqlst.solutions) |
|
63 |
|
64 def test_0_10(self): |
|
65 rqlst = self._prepare('Any X WHERE X concerne Y, Y is Note') |
|
66 self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
67 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False) |
|
68 |
|
69 def test_0_11(self): |
|
70 rqlst = self._prepare('Any X WHERE X todo_by Y, X is Affaire') |
|
71 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
72 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, True) |
|
73 |
|
74 def test_0_12(self): |
|
75 rqlst = self._prepare('Personne P WHERE P concerne A, A concerne S, S nom "Logilab"') |
|
76 self.assertEquals(rqlst.defined_vars['P']._q_invariant, True) |
|
77 self.assertEquals(rqlst.defined_vars['A']._q_invariant, True) |
|
78 self.assertEquals(rqlst.defined_vars['S']._q_invariant, False) |
|
79 |
|
80 def test_1_0(self): |
|
81 rqlst = self._prepare('Any X,Y WHERE X created_by Y, X eid 5, NOT Y eid 6') |
|
82 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, True) |
|
83 |
|
84 def test_1_1(self): |
|
85 rqlst = self._prepare('Any X,Y WHERE X created_by Y, X eid 5, NOT Y eid IN (6,7)') |
|
86 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, True) |
|
87 |
|
88 def test_2(self): |
|
89 rqlst = self._prepare('Any X WHERE X identity Y, Y eid 1') |
|
90 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
91 |
|
92 def test_7(self): |
|
93 rqlst = self._prepare('Personne X,Y where X nom NX, Y nom NX, X eid XE, not Y eid XE') |
|
94 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
95 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False) |
|
96 |
|
97 def test_optional_inlined(self): |
|
98 rqlst = self._prepare('Any X,S where X from_state S?') |
|
99 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
100 self.assertEquals(rqlst.defined_vars['S']._q_invariant, True) |
|
101 |
|
102 def test_optional_inlined_2(self): |
|
103 rqlst = self._prepare('Any N,A WHERE N? inline1 A') |
|
104 self.assertEquals(rqlst.defined_vars['N']._q_invariant, False) |
|
105 self.assertEquals(rqlst.defined_vars['A']._q_invariant, False) |
|
106 |
|
107 def test_optional_1(self): |
|
108 rqlst = self._prepare('Any X,S WHERE X travaille S?') |
|
109 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
110 self.assertEquals(rqlst.defined_vars['S']._q_invariant, True) |
|
111 |
|
112 def test_greater_eid(self): |
|
113 rqlst = self._prepare('Any X WHERE X eid > 5') |
|
114 self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
115 |
|
116 def test_greater_eid_typed(self): |
|
117 rqlst = self._prepare('Any X WHERE X eid > 5, X is Note') |
|
118 self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
119 |
|
120 def test_max_eid(self): |
|
121 rqlst = self._prepare('Any MAX(X)') |
|
122 self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
123 |
|
124 def test_max_eid_typed(self): |
|
125 rqlst = self._prepare('Any MAX(X) WHERE X is Note') |
|
126 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
127 |
|
128 def test_all_entities(self): |
|
129 rqlst = self._prepare('Any X') |
|
130 self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
131 |
|
132 def test_all_typed_entity(self): |
|
133 rqlst = self._prepare('Any X WHERE X is Note') |
|
134 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
135 |
|
136 def test_has_text_1(self): |
|
137 rqlst = self._prepare('Any X WHERE X has_text "toto tata"') |
|
138 self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
139 self.assertEquals(rqlst.defined_vars['X'].stinfo['principal'].r_type, 'has_text') |
|
140 |
|
141 def test_has_text_2(self): |
|
142 rqlst = self._prepare('Any X WHERE X is Personne, X has_text "coucou"') |
|
143 self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
144 self.assertEquals(rqlst.defined_vars['X'].stinfo['principal'].r_type, 'has_text') |
|
145 |
|
146 def test_not_relation_1(self): |
|
147 # P can't be invariant since deambiguification caused by "NOT X require_permission P" |
|
148 # is not considered by generated sql (NOT EXISTS(...)) |
|
149 rqlst = self._prepare('Any P,G WHERE P require_group G, NOT X require_permission P') |
|
150 self.assertEquals(rqlst.defined_vars['P']._q_invariant, False) |
|
151 self.assertEquals(rqlst.defined_vars['G']._q_invariant, True) |
|
152 self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
153 |
|
154 def test_not_relation_2(self): |
|
155 rqlst = self._prepare('TrInfo X WHERE X eid 2, NOT X from_state Y, Y is State') |
|
156 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, True) |
|
157 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
158 |
|
159 def test_not_relation_3(self): |
|
160 rqlst = self._prepare('Any X, Y WHERE X eid 1, Y eid in (2, 3)') |
|
161 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False) |
|
162 |
|
163 def test_not_relation_4_1(self): |
|
164 rqlst = self._prepare('Note X WHERE NOT Y evaluee X') |
|
165 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
166 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, True) |
|
167 |
|
168 def test_not_relation_4_2(self): |
|
169 rqlst = self._prepare('Any X WHERE NOT Y evaluee X') |
|
170 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
171 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, True) |
|
172 |
|
173 def test_not_relation_4_3(self): |
|
174 rqlst = self._prepare('Any Y WHERE NOT Y evaluee X') |
|
175 self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
176 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False) |
|
177 |
|
178 def test_not_relation_4_4(self): |
|
179 rqlst = self._prepare('Any X WHERE NOT Y evaluee X, Y is EUser') |
|
180 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
181 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False) |
|
182 |
|
183 def test_not_relation_4_5(self): |
|
184 rqlst = self._prepare('Any X WHERE NOT Y evaluee X, Y eid %s, X is Note' % self.ueid) |
|
185 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
186 self.assertEquals(rqlst.solutions, [{'X': 'Note'}]) |
|
187 |
|
188 def test_not_relation_5_1(self): |
|
189 rqlst = self._prepare('Any X,Y WHERE X name "EGroup", Y eid IN(1, 2, 3), NOT X read_permission Y') |
|
190 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
191 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False) |
|
192 |
|
193 def test_not_relation_5_2(self): |
|
194 rqlst = self._prepare('DISTINCT Any X,Y WHERE X name "EGroup", Y eid IN(1, 2, 3), NOT X read_permission Y') |
|
195 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
196 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False) |
|
197 |
|
198 def test_not_relation_6(self): |
|
199 rqlst = self._prepare('Personne P where NOT P concerne A') |
|
200 self.assertEquals(rqlst.defined_vars['P']._q_invariant, False) |
|
201 self.assertEquals(rqlst.defined_vars['A']._q_invariant, True) |
|
202 |
|
203 def test_not_relation_7(self): |
|
204 rqlst = self._prepare('Any K,V WHERE P is EProperty, P pkey K, P value V, NOT P for_user U') |
|
205 self.assertEquals(rqlst.defined_vars['P']._q_invariant, False) |
|
206 self.assertEquals(rqlst.defined_vars['U']._q_invariant, True) |
|
207 |
|
208 def test_exists_1(self): |
|
209 rqlst = self._prepare('Any U WHERE U eid IN (1,2), EXISTS(X owned_by U)') |
|
210 self.assertEquals(rqlst.defined_vars['U']._q_invariant, False) |
|
211 self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
212 |
|
213 def test_exists_2(self): |
|
214 rqlst = self._prepare('Any U WHERE EXISTS(U eid IN (1,2), X owned_by U)') |
|
215 self.assertEquals(rqlst.defined_vars['U']._q_invariant, False) |
|
216 self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
217 |
|
218 def test_exists_3(self): |
|
219 rqlst = self._prepare('Any U WHERE EXISTS(X owned_by U, X bookmarked_by U)') |
|
220 self.assertEquals(rqlst.defined_vars['U']._q_invariant, False) |
|
221 self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
222 |
|
223 def test_exists_4(self): |
|
224 rqlst = self._prepare('Any X,Y WHERE X name "EGroup", Y eid IN(1, 2, 3), EXISTS(X read_permission Y)') |
|
225 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
226 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False) |
|
227 |
|
228 def test_exists_5(self): |
|
229 rqlst = self._prepare('DISTINCT Any X,Y WHERE X name "EGroup", Y eid IN(1, 2, 3), EXISTS(X read_permission Y)') |
|
230 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
231 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, True) |
|
232 |
|
233 def test_not_exists_1(self): |
|
234 rqlst = self._prepare('Any U WHERE NOT EXISTS(X owned_by U, X bookmarked_by U)') |
|
235 self.assertEquals(rqlst.defined_vars['U']._q_invariant, False) |
|
236 self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
237 |
|
238 def test_not_exists_2(self): |
|
239 rqlst = self._prepare('Any X,Y WHERE X name "EGroup", Y eid IN(1, 2, 3), NOT EXISTS(X read_permission Y)') |
|
240 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False) |
|
241 |
|
242 def test_not_exists_distinct_1(self): |
|
243 rqlst = self._prepare('DISTINCT Any X,Y WHERE X name "EGroup", Y eid IN(1, 2, 3), NOT EXISTS(X read_permission Y)') |
|
244 self.assertEquals(rqlst.defined_vars['Y']._q_invariant, False) |
|
245 |
|
246 def test_or_1(self): |
|
247 rqlst = self._prepare('Any X WHERE X concerne B OR C concerne X, B eid 12, C eid 13') |
|
248 self.assertEquals(rqlst.defined_vars['X']._q_invariant, False) |
|
249 |
|
250 def test_or_2(self): |
|
251 rqlst = self._prepare('Any X WHERE X created_by U, X concerne B OR C concerne X, B eid 12, C eid 13') |
|
252 self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
253 self.assertEquals(rqlst.defined_vars['U']._q_invariant, True) |
|
254 self.assertEquals(rqlst.defined_vars['X'].stinfo['principal'].r_type, 'created_by') |
|
255 |
|
256 def test_or_3(self): |
|
257 rqlst = self._prepare('Any N WHERE A evaluee N or EXISTS(N todo_by U)') |
|
258 self.assertEquals(rqlst.defined_vars['N']._q_invariant, False) |
|
259 self.assertEquals(rqlst.defined_vars['A']._q_invariant, True) |
|
260 self.assertEquals(rqlst.defined_vars['U']._q_invariant, True) |
|
261 |
|
262 def test_or_exists_1(self): |
|
263 # query generated by security rewriting |
|
264 rqlst = self._prepare('DISTINCT Any A,S WHERE A is Affaire, S nom "chouette", S is IN(Division, Societe, SubDivision),' |
|
265 '(EXISTS(A owned_by %(D)s)) ' |
|
266 'OR ((((EXISTS(E concerne C?, C owned_by %(D)s, A identity E, C is Note, E is Affaire)) ' |
|
267 'OR (EXISTS(I concerne H?, H owned_by %(D)s, H is Societe, A identity I, I is Affaire))) ' |
|
268 'OR (EXISTS(J concerne G?, G owned_by %(D)s, G is SubDivision, A identity J, J is Affaire))) ' |
|
269 'OR (EXISTS(K concerne F?, F owned_by %(D)s, F is Division, A identity K, K is Affaire)))') |
|
270 self.assertEquals(rqlst.defined_vars['A']._q_invariant, False) |
|
271 self.assertEquals(rqlst.defined_vars['S']._q_invariant, False) |
|
272 |
|
273 def test_or_exists_2(self): |
|
274 rqlst = self._prepare('Any U WHERE EXISTS(U in_group G, G name "managers") OR EXISTS(X owned_by U, X bookmarked_by U)') |
|
275 self.assertEquals(rqlst.defined_vars['U']._q_invariant, False) |
|
276 self.assertEquals(rqlst.defined_vars['G']._q_invariant, False) |
|
277 self.assertEquals(rqlst.defined_vars['X']._q_invariant, True) |
|
278 |
|
279 def test_or_exists_3(self): |
|
280 rqlst = self._prepare('Any COUNT(S),CS GROUPBY CS ORDERBY 1 DESC LIMIT 10 ' |
|
281 'WHERE C is Societe, S concerne C, C nom CS, ' |
|
282 '(EXISTS(S owned_by 1)) OR (EXISTS(S documented_by N, N title "published"))') |
|
283 self.assertEquals(rqlst.defined_vars['S']._q_invariant, True) |
|
284 rqlst = self._prepare('Any COUNT(S),CS GROUPBY CS ORDERBY 1 DESC LIMIT 10 ' |
|
285 'WHERE S is Affaire, C is Societe, S concerne C, C nom CS, ' |
|
286 '(EXISTS(S owned_by 1)) OR (EXISTS(S documented_by N, N title "published"))') |
|
287 self.assertEquals(rqlst.defined_vars['S']._q_invariant, True) |
|
288 |
|
289 if __name__ == '__main__': |
|
290 from logilab.common.testlib import unittest_main |
|
291 unittest_main() |