home · contact · privacy
Slightly improve and re-organize Condition tests.
[plomtask] / tests / misc.py
index 87b3a6e1bc53099e195d1a97ec5fafea3a867035..a27f0d0a1f8c0a3330be0e6c6906e3a7d6d53fd2 100644 (file)
 """Miscellaneous tests."""
 from unittest import TestCase
 from tests.utils import TestCaseWithServer
-from plomtask.http import ParamsParser, PostvarsParser
+from plomtask.http import InputsParser
 from plomtask.exceptions import BadFormatException
 
 
 class TestsSansServer(TestCase):
     """Tests that do not require DB setup or a server."""
 
-    def test_params_parser(self) -> None:
-        """Test behavior of ParamsParser."""
-        self.assertEqual('',
-                         ParamsParser({}).get_str('foo'))
-        self.assertEqual('bar',
-                         ParamsParser({}).get_str('foo', 'bar'))
-        self.assertEqual('bar',
-                         ParamsParser({'foo': []}).get_str('foo', 'bar'))
-        self.assertEqual('baz',
-                         ParamsParser({'foo': ['baz']}).get_str('foo', 'bar'))
-        self.assertEqual(None,
-                         ParamsParser({}).get_int_or_none('foo'))
-        self.assertEqual(None,
-                         ParamsParser({'foo': []}).get_int_or_none('foo'))
-        self.assertEqual(None,
-                         ParamsParser({'foo': ['']}).get_int_or_none('foo'))
-        self.assertEqual(0,
-                         ParamsParser({'foo': ['0']}).get_int_or_none('foo'))
+    def test_InputsParser_get_str(self) -> None:
+        """Test InputsParser.get_str on strict and non-strictk."""
+        parser = InputsParser({}, False)
+        self.assertEqual('', parser.get_str('foo'))
+        self.assertEqual('bar', parser.get_str('foo', 'bar'))
+        parser.strict = True
         with self.assertRaises(BadFormatException):
-            ParamsParser({'foo': ['None']}).get_int_or_none('foo')
+            parser.get_str('foo')
         with self.assertRaises(BadFormatException):
-            ParamsParser({'foo': ['0.1']}).get_int_or_none('foo')
-        self.assertEqual(23,
-                         ParamsParser({'foo': ['23']}).get_int_or_none('foo'))
-
-    def test_postvars_parser(self) -> None:
-        """Test behavior of PostvarsParser."""
-        self.assertEqual([],
-                         PostvarsParser({}).get_all_str('foo'))
-        self.assertEqual([],
-                         PostvarsParser({'foo': []}).get_all_str('foo'))
-        self.assertEqual(['bar'],
-                         PostvarsParser({'foo': ['bar']}).get_all_str('foo'))
-        self.assertEqual(['bar', 'baz'],
-                         PostvarsParser({'foo': ['bar', 'baz']}).
-                         get_all_str('foo'))
-        self.assertEqual([],
-                         PostvarsParser({}).get_all_int('foo'))
-        self.assertEqual([],
-                         PostvarsParser({'foo': []}).get_all_int('foo'))
-        self.assertEqual([],
-                         PostvarsParser({'foo': ['']}).get_all_int('foo'))
-        self.assertEqual([0],
-                         PostvarsParser({'foo': ['0']}).get_all_int('foo'))
-        self.assertEqual([0, 17],
-                         PostvarsParser({'foo': ['0', '17']}).
-                         get_all_int('foo'))
-        with self.assertRaises(BadFormatException):
-            PostvarsParser({'foo': ['0.1', '17']}).get_all_int('foo')
-        with self.assertRaises(BadFormatException):
-            PostvarsParser({'foo': ['None', '17']}).get_all_int('foo')
-        with self.assertRaises(BadFormatException):
-            PostvarsParser({}).get_str('foo')
-        with self.assertRaises(BadFormatException):
-            PostvarsParser({'foo': []}).get_str('foo')
-        self.assertEqual('bar',
-                         PostvarsParser({'foo': ['bar']}).get_str('foo'))
-        self.assertEqual('',
-                         PostvarsParser({'foo': ['', 'baz']}).get_str('foo'))
-        with self.assertRaises(BadFormatException):
-            PostvarsParser({}).get_int('foo')
-        with self.assertRaises(BadFormatException):
-            PostvarsParser({'foo': []}).get_int('foo')
-        with self.assertRaises(BadFormatException):
-            PostvarsParser({'foo': ['']}).get_int('foo')
-        with self.assertRaises(BadFormatException):
-            PostvarsParser({'foo': ['bar']}).get_int('foo')
-        with self.assertRaises(BadFormatException):
-            PostvarsParser({'foo': ['0.1']}).get_int('foo')
-        self.assertEqual(0,
-                         PostvarsParser({'foo': ['0']}).get_int('foo'))
-        self.assertEqual(17,
-                         PostvarsParser({'foo': ['17', '23']}).get_int('foo'))
+            parser.get_str('foo', 'bar')
+        parser = InputsParser({'foo': []}, False)
+        self.assertEqual('bar', parser.get_str('foo', 'bar'))
         with self.assertRaises(BadFormatException):
-            PostvarsParser({}).get_float('foo')
-        with self.assertRaises(BadFormatException):
-            PostvarsParser({'foo': []}).get_float('foo')
-        with self.assertRaises(BadFormatException):
-            PostvarsParser({'foo': ['']}).get_float('foo')
-        with self.assertRaises(BadFormatException):
-            PostvarsParser({'foo': ['bar']}).get_float('foo')
-        self.assertEqual(0,
-                         PostvarsParser({'foo': ['0']}).get_float('foo'))
-        self.assertEqual(0.1,
-                         PostvarsParser({'foo': ['0.1']}).get_float('foo'))
-        self.assertEqual(1.23,
-                         PostvarsParser({'foo': ['1.23', '456']}).
-                         get_float('foo'))
+            InputsParser({'foo': []}, True).get_str('foo', 'bar')
+        for strictness in (False, True):
+            parser = InputsParser({'foo': ['baz']}, strictness)
+            self.assertEqual('baz', parser.get_str('foo', 'bar'))
+            parser = InputsParser({'foo': ['baz', 'quux']}, strictness)
+            self.assertEqual('baz', parser.get_str('foo', 'bar'))
+
+    def test_InputsParser_get_first_strings_starting(self) -> None:
+        """Test InputsParser.get_first_strings_starting [non-]strict."""
+        for strictness in (False, True):
+            parser = InputsParser({}, strictness)
+            self.assertEqual({},
+                             parser.get_first_strings_starting(''))
+            parser = InputsParser({}, strictness)
+            self.assertEqual({},
+                             parser.get_first_strings_starting('foo'))
+            parser = InputsParser({'foo': ['bar']}, strictness)
+            self.assertEqual({'foo': 'bar'},
+                             parser.get_first_strings_starting(''))
+            parser = InputsParser({'x': ['y']}, strictness)
+            self.assertEqual({'x': 'y'},
+                             parser.get_first_strings_starting('x'))
+            parser = InputsParser({'xx': ['y']}, strictness)
+            self.assertEqual({'xx': 'y'},
+                             parser.get_first_strings_starting('x'))
+            parser = InputsParser({'xx': ['y']}, strictness)
+            self.assertEqual({},
+                             parser.get_first_strings_starting('xxx'))
+            d = {'xxx': ['x'], 'xxy': ['y'], 'xyy': ['z']}
+            parser = InputsParser(d, strictness)
+            self.assertEqual({'xxx': 'x', 'xxy': 'y'},
+                             parser.get_first_strings_starting('xx'))
+            d = {'xxx': ['x', 'y', 'z'], 'xxy': ['y', 'z']}
+            parser = InputsParser(d, strictness)
+            self.assertEqual({'xxx': 'x', 'xxy': 'y'},
+                             parser.get_first_strings_starting('xx'))
+
+    def test_InputsParser_get_int(self) -> None:
+        """Test InputsParser.get_int on strict and non-strict."""
+        for strictness in (False, True):
+            with self.assertRaises(BadFormatException):
+                InputsParser({}, strictness).get_int('foo')
+            with self.assertRaises(BadFormatException):
+                InputsParser({'foo': []}, strictness).get_int('foo')
+            with self.assertRaises(BadFormatException):
+                InputsParser({'foo': ['']}, strictness).get_int('foo')
+            with self.assertRaises(BadFormatException):
+                InputsParser({'foo': ['bar']}, strictness).get_int('foo')
+            with self.assertRaises(BadFormatException):
+                InputsParser({'foo': ['0.1']}).get_int('foo')
+            parser = InputsParser({'foo': ['0']}, strictness)
+            self.assertEqual(0, parser.get_int('foo'))
+            parser = InputsParser({'foo': ['17', '23']}, strictness)
+            self.assertEqual(17, parser.get_int('foo'))
+
+    def test_InputsParser_get_int_or_none(self) -> None:
+        """Test InputsParser.get_int_or_none on strict and non-strict."""
+        for strictness in (False, True):
+            parser = InputsParser({}, strictness)
+            self.assertEqual(None, parser.get_int_or_none('foo'))
+            parser = InputsParser({'foo': []}, strictness)
+            self.assertEqual(None, parser.get_int_or_none('foo'))
+            parser = InputsParser({'foo': ['']}, strictness)
+            self.assertEqual(None, parser.get_int_or_none('foo'))
+            parser = InputsParser({'foo': ['0']}, strictness)
+            self.assertEqual(0, parser.get_int_or_none('foo'))
+            with self.assertRaises(BadFormatException):
+                InputsParser({'foo': ['None']},
+                             strictness).get_int_or_none('foo')
+            with self.assertRaises(BadFormatException):
+                InputsParser({'foo': ['0.1']},
+                             strictness).get_int_or_none('foo')
+            parser = InputsParser({'foo': ['23']}, strictness)
+            self.assertEqual(23, parser.get_int_or_none('foo'))
+
+    def test_InputsParser_get_float(self) -> None:
+        """Test InputsParser.get_float on strict and non-strict."""
+        for strictness in (False, True):
+            with self.assertRaises(BadFormatException):
+                InputsParser({}, strictness).get_float('foo')
+            with self.assertRaises(BadFormatException):
+                InputsParser({'foo': []}, strictness).get_float('foo')
+            with self.assertRaises(BadFormatException):
+                InputsParser({'foo': ['']}, strictness).get_float('foo')
+            with self.assertRaises(BadFormatException):
+                InputsParser({'foo': ['bar']}, strictness).get_float('foo')
+            parser = InputsParser({'foo': ['0']}, strictness)
+            self.assertEqual(0, parser.get_float('foo'))
+            parser = InputsParser({'foo': ['0.1']}, strictness)
+            self.assertEqual(0.1, parser.get_float('foo'))
+            parser = InputsParser({'foo': ['1.23', '456']}, strictness)
+            self.assertEqual(1.23, parser.get_float('foo'))
+
+    def test_InputsParser_get_all_str(self) -> None:
+        """Test InputsParser.get_all_str on strict and non-strict."""
+        for strictness in (False, True):
+            parser = InputsParser({}, strictness)
+            self.assertEqual([], parser.get_all_str('foo'))
+            parser = InputsParser({'foo': []}, strictness)
+            self.assertEqual([], parser.get_all_str('foo'))
+            parser = InputsParser({'foo': ['bar']}, strictness)
+            self.assertEqual(['bar'], parser.get_all_str('foo'))
+            parser = InputsParser({'foo': ['bar', 'baz']}, strictness)
+            self.assertEqual(['bar', 'baz'], parser.get_all_str('foo'))
+
+    def test_InputsParser_strict_get_all_int(self) -> None:
+        """Test InputsParser.get_all_int on strict and non-strict."""
+        for strictness in (False, True):
+            parser = InputsParser({}, strictness)
+            self.assertEqual([], parser.get_all_int('foo'))
+            parser = InputsParser({'foo': []}, strictness)
+            self.assertEqual([], parser.get_all_int('foo'))
+            parser = InputsParser({'foo': ['']}, strictness)
+            self.assertEqual([], parser.get_all_int('foo'))
+            parser = InputsParser({'foo': ['0']}, strictness)
+            self.assertEqual([0], parser.get_all_int('foo'))
+            parser = InputsParser({'foo': ['0', '17']}, strictness)
+            self.assertEqual([0, 17], parser.get_all_int('foo'))
+            parser = InputsParser({'foo': ['0.1', '17']}, strictness)
+            with self.assertRaises(BadFormatException):
+                parser.get_all_int('foo')
+            parser = InputsParser({'foo': ['None', '17']}, strictness)
+            with self.assertRaises(BadFormatException):
+                parser.get_all_int('foo')
 
 
 class TestsWithServer(TestCaseWithServer):
     """Tests against our HTTP server/handler (and database)."""
 
     def test_do_GET(self) -> None:
-        """Test / redirect, and unknown targets failing."""
+        """Test GET / redirect, and unknown targets failing."""
         self.conn.request('GET', '/')
         self.check_redirect('/day')
         self.check_get('/foo', 404)