server/test/unittest_ssplanner.py
changeset 0 b97547f5f1fa
child 47 54087a269bdd
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/server/test/unittest_ssplanner.py	Wed Nov 05 15:52:50 2008 +0100
@@ -0,0 +1,58 @@
+from cubicweb.devtools import init_test_database
+from cubicweb.devtools.repotest import BasePlannerTC, test_plan
+from cubicweb.server.ssplanner import SSPlanner
+
+# keep cnx so it's not garbage collected and the associated session is closed
+repo, cnx = init_test_database('sqlite')
+
+class SSPlannerTC(BasePlannerTC):
+    repo = repo
+    _test = test_plan
+    
+    def setUp(self):
+        BasePlannerTC.setUp(self)
+        self.planner = SSPlanner(self.o.schema, self.o._rqlhelper)
+        self.system = self.o._repo.system_source
+
+    def tearDown(self):
+        BasePlannerTC.tearDown(self)
+
+    def test_ordered_ambigous_sol(self):
+        self._test('Any XN ORDERBY XN WHERE X name XN',
+                   [('OneFetchStep', [('Any XN ORDERBY XN WHERE X name XN',
+                                       [{'X': 'Basket', 'XN': 'String'},
+                                        {'X': 'EConstraintType', 'XN': 'String'},
+                                        {'X': 'EEType', 'XN': 'String'},
+                                        {'X': 'EGroup', 'XN': 'String'},
+                                        {'X': 'EPermission', 'XN': 'String'},
+                                        {'X': 'ERType', 'XN': 'String'},
+                                        {'X': 'File', 'XN': 'String'},
+                                        {'X': 'Folder', 'XN': 'String'},
+                                        {'X': 'Image', 'XN': 'String'},
+                                        {'X': 'State', 'XN': 'String'},
+                                        {'X': 'Tag', u'XN': 'String'},
+                                        {'X': 'Transition', 'XN': 'String'}])],
+                     None, None, 
+                     [self.system], None, [])])
+    
+    def test_groupeded_ambigous_sol(self):
+        self._test('Any XN,COUNT(X) GROUPBY XN WHERE X name XN',
+                   [('OneFetchStep', [('Any XN,COUNT(X) GROUPBY XN WHERE X name XN',
+                                       [{'X': 'Basket', 'XN': 'String'},
+                                        {'X': 'EConstraintType', 'XN': 'String'},
+                                        {'X': 'EEType', 'XN': 'String'},
+                                        {'X': 'EGroup', 'XN': 'String'},
+                                        {'X': 'EPermission', 'XN': 'String'},
+                                        {'X': 'ERType', 'XN': 'String'},
+                                        {'X': 'File', 'XN': 'String'},
+                                        {'X': 'Folder', 'XN': 'String'},
+                                        {'X': 'Image', 'XN': 'String'},
+                                        {'X': 'State', 'XN': 'String'},
+                                        {'X': 'Tag', u'XN': 'String'},
+                                        {'X': 'Transition', 'XN': 'String'}])],
+                     None, None, 
+                     [self.system], None, [])])
+        
+if __name__ == '__main__':
+    from logilab.common.testlib import unittest_main
+    unittest_main()