home · contact · privacy
Perform sensible redirects on POSTs.
[plomtask] / tests / utils.py
index d41e7b39ad5fe07abdc701be674d9f81678cd30f..2a919a31dbb057f4db558861d2fafe8277db5521 100644 (file)
@@ -8,12 +8,21 @@ from os import remove as remove_file
 from typing import Mapping
 from plomtask.db import DatabaseFile, DatabaseConnection
 from plomtask.http import TaskHandler, TaskServer
+from plomtask.processes import Process, ProcessStep
+from plomtask.conditions import Condition
+from plomtask.days import Day
+from plomtask.todos import Todo
 
 
 class TestCaseWithDB(TestCase):
     """Module tests not requiring DB setup."""
 
     def setUp(self) -> None:
+        Condition.empty_cache()
+        Day.empty_cache()
+        Process.empty_cache()
+        ProcessStep.empty_cache()
+        Todo.empty_cache()
         timestamp = datetime.now().timestamp()
         self.db_file = DatabaseFile(f'test_db:{timestamp}')
         self.db_file.remake()
@@ -56,11 +65,13 @@ class TestCaseWithServer(TestCaseWithDB):
     def check_post(self, data: Mapping[str, object], target: str,
                    expected_code: int, redirect_location: str = '') -> None:
         """Check that POST of data to target yields expected_code."""
-        encoded_form_data = urlencode(data).encode('utf-8')
+        encoded_form_data = urlencode(data, doseq=True).encode('utf-8')
         headers = {'Content-Type': 'application/x-www-form-urlencoded',
                    'Content-Length': str(len(encoded_form_data))}
         self.conn.request('POST', target,
                           body=encoded_form_data, headers=headers)
+        if redirect_location == '':
+            redirect_location = target
         if 302 == expected_code:
             self.check_redirect(redirect_location)
         else: