X-Git-Url: https://plomlompom.com/repos/%7B%7Bprefix%7D%7D/copy_structured?a=blobdiff_plain;f=tests%2Ftest_days.py;h=08ce637501887b86bb626a465a19a1e1cae4ece5;hb=fba983f72a30a9e30c905e5fc874d8843322a271;hp=3a6c6331c689b482d5a14296c4d5a07f747579ac;hpb=0478742f92480b4663f0c636505474afc15ed441;p=plomtask diff --git a/tests/test_days.py b/tests/test_days.py index 3a6c633..08ce637 100644 --- a/tests/test_days.py +++ b/tests/test_days.py @@ -1,7 +1,11 @@ """Test days module.""" from unittest import TestCase +from threading import Thread +from http.client import HTTPConnection +from urllib.parse import urlencode from datetime import datetime from os import remove as remove_file +from plomtask.http import TaskHandler, TaskServer from plomtask.days import Day from plomtask.misc import HandledException from plomtask.db import DatabaseFile, DatabaseConnection @@ -83,7 +87,7 @@ class TestsWithDB(TestCase): [day1, day2, day3]) self.assertEqual(Day.all(self.db_conn, ('', '2024-01-02')), [day1, day2]) - self.assertEqual(Day.all(self.db_conn, ('2024-01-03, 2024-01-01')), + self.assertEqual(Day.all(self.db_conn, ('2024-01-03', '2024-01-01')), []) def test_Day_comment(self): @@ -97,3 +101,50 @@ class TestsWithDB(TestCase): d2.save(self.db_conn) day_retrieved = Day.by_date(self.db_conn, d2.date) self.assertEqual(day_retrieved.comment, 'foo') + + +class TestsWithServer(TestsWithDB): + """Tests against our HTTP server/handler (and database).""" + + def setUp(self): + super().setUp() + self.httpd = TaskServer(self.db_file, ('localhost', 0), TaskHandler) + self.server_thread = Thread(target=self.httpd.serve_forever) + self.server_thread.daemon = True + self.server_thread.start() + + def test_do_POST_day(self): + """Test POST /day and its effect on the database.""" + http_conn = HTTPConnection(*self.httpd.server_address) + form_data = {'comment': 'foo'} + encoded_form_data = urlencode(form_data).encode('utf-8') + headers = {'Content-Type': 'application/x-www-form-urlencoded', + 'Content-Length': str(len(encoded_form_data))} + http_conn.request('POST', '/day?date=FOO', + body=encoded_form_data, headers=headers) + self.assertEqual(http_conn.getresponse().status, 400) + self.assertEqual(Day.all(self.db_conn), []) + http_conn.request('POST', '/day?date=2024-01-01', + body=encoded_form_data, headers=headers) + self.assertEqual(http_conn.getresponse().status, 302) + retrieved = Day.by_date(self.db_conn, '2024-01-01') + self.assertEqual(retrieved.comment, 'foo') + self.assertEqual(Day.all(self.db_conn), [retrieved]) + + def test_do_GET(self): + """Test /day and /calendar response codes.""" + http_conn = HTTPConnection(*self.httpd.server_address) + http_conn.request('GET', '/day') + self.assertEqual(http_conn.getresponse().status, 200) + http_conn.request('GET', '/day?date=3000-01-01') + self.assertEqual(http_conn.getresponse().status, 200) + http_conn.request('GET', '/day?date=FOO') + self.assertEqual(http_conn.getresponse().status, 400) + http_conn.request('GET', '/calendar') + self.assertEqual(http_conn.getresponse().status, 200) + + def tearDown(self): + self.httpd.shutdown() + self.httpd.server_close() + self.server_thread.join() + super().tearDown()