tests/model_validate.py
branchdevel
changeset 207 90a81145852c
child 209 7a0f8fbdf7b8
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/tests/model_validate.py	Fri Mar 02 03:01:46 2012 +0100
@@ -0,0 +1,46 @@
+from iro.model.schema import Offer
+from iro.model.decorators import vRoute
+from iro.model.pool import data
+
+from iro.error import ValidateException
+
+from .dbtestcase import DBTestCase
+
+class DummyPool():
+    def run(self, f,*a,**k):
+        return f(*a,**k)
+
+class ModelVaidatorTest(DBTestCase):
+    """tests for the model vaidators"""
+    def setUp(self):
+        DBTestCase.setUp(self)
+        self.pool = data.pool
+        data.pool = DummyPool()
+
+    def tearDown(self):
+        data.pool = self.pool
+        self.pool = None
+        DBTestCase.tearDown(self)
+
+    def testTyp(self):
+        pass
+    testTyp.todo = "To implement"
+
+    def testRoute(self):
+        with self.session() as session:
+            session.add(Offer(name="t",provider="p",typ="type"))
+        vR = vRoute('type')
+        self.assertEqual(vR("t",None),"t")
+        self.assertEqual(vR(["t","t"],None),["t"])
+        e = self.assertRaises(ValidateException,vR, "s", None)
+        self.assertEqual(str(e),'700:Route s is not valid.')
+
+    def testRouteAllow(self):
+        with self.session() as session:
+            session.add(Offer(name="t",provider="p",typ="type"))
+        vR = vRoute('type')
+        e = self.assertRaises(ValidateException,vR, "t", "foo", allowString=False)
+        self.assertEqual(str(e),'700:foo must be a list of routes.')
+        e = self.assertRaises(ValidateException,vR, ["t"], "foo", allowList=False)
+        self.assertEqual(str(e),'700:foo must be a route - No list of routes.')
+