X-Git-Url: https://plomlompom.com/repos/foo.html?a=blobdiff_plain;f=tests%2Ftest_days.py;h=3a6c6331c689b482d5a14296c4d5a07f747579ac;hb=0478742f92480b4663f0c636505474afc15ed441;hp=828e5e895f8a53c6ad71bb65c151721ec6b7a5a7;hpb=b16ae56b9c1a5bb799594fdd759a400d40488350;p=plomtask diff --git a/tests/test_days.py b/tests/test_days.py index 828e5e8..3a6c633 100644 --- a/tests/test_days.py +++ b/tests/test_days.py @@ -1,12 +1,14 @@ """Test days module.""" from unittest import TestCase from datetime import datetime +from os import remove as remove_file from plomtask.days import Day from plomtask.misc import HandledException +from plomtask.db import DatabaseFile, DatabaseConnection -class DayTests(TestCase): - """Tests for testing the days module.""" +class TestsSansDB(TestCase): + """Days module tests not requiring DB setup.""" def test_Day_dates(self): """Test Day's date format.""" @@ -33,3 +35,65 @@ class DayTests(TestCase): def test_Day_weekday(self): """Test Day.weekday.""" self.assertEqual(Day('2024-03-17').weekday, 'Sunday') + + +class TestsWithDB(TestCase): + """Days module tests not requiring DB setup.""" + + def setUp(self): + timestamp = datetime.now().timestamp() + self.db_file = DatabaseFile(f'test_db:{timestamp}') + self.db_file.remake() + self.db_conn = DatabaseConnection(self.db_file) + + def tearDown(self): + self.db_conn.close() + remove_file(self.db_file.path) + + def test_Day_by_date(self): + """Test Day.by_date().""" + self.assertEqual(None, Day.by_date(self.db_conn, '2024-01-01')) + Day('2024-01-01').save(self.db_conn) + self.assertEqual(Day('2024-01-01'), + Day.by_date(self.db_conn, '2024-01-01')) + self.assertEqual(None, + Day.by_date(self.db_conn, '2024-01-02')) + self.assertEqual(Day('2024-01-02'), + Day.by_date(self.db_conn, '2024-01-02', create=True)) + + def test_Day_all(self): + """Test Day.all(), especially in regards to date range filtering.""" + day1 = Day('2024-01-01') + day2 = Day('2024-01-02') + day3 = Day('2024-01-03') + day1.save(self.db_conn) + day2.save(self.db_conn) + day3.save(self.db_conn) + self.assertEqual(Day.all(self.db_conn), + [day1, day2, day3]) + self.assertEqual(Day.all(self.db_conn, ('', '')), + [day1, day2, day3]) + self.assertEqual(Day.all(self.db_conn, ('2024-01-01', '2024-01-03')), + [day1, day2, day3]) + self.assertEqual(Day.all(self.db_conn, ('2024-01-02', '2024-01-03')), + [day2, day3]) + self.assertEqual(Day.all(self.db_conn, ('2024-01-03', '')), + [day3]) + self.assertEqual(Day.all(self.db_conn, ('2024-01-01', '')), + [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')), + []) + + def test_Day_comment(self): + """Test Day.by_date().""" + self.assertEqual(None, Day.by_date(self.db_conn, '2024-01-01')) + d1 = Day('2024-01-01') + d1.save(self.db_conn) + day_retrieved = Day.by_date(self.db_conn, d1.date) + self.assertEqual(day_retrieved.comment, '') + d2 = Day('2024-01-02', 'foo') + d2.save(self.db_conn) + day_retrieved = Day.by_date(self.db_conn, d2.date) + self.assertEqual(day_retrieved.comment, 'foo')