X-Git-Url: https://plomlompom.com/repos/condition_titles?a=blobdiff_plain;f=tests%2Ftest_days.py;h=5e3713882ca622d207026792f2f47df23d807283;hb=e51477ebea9fb701d88de85088b2fda1247c73a2;hp=7805208e749a664a655b97103ab3705799e062b1;hpb=4907c8d031ece55f84123293e28648cdc8e9619e;p=plomtask diff --git a/tests/test_days.py b/tests/test_days.py index 7805208..5e37138 100644 --- a/tests/test_days.py +++ b/tests/test_days.py @@ -1,15 +1,17 @@ """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.""" def test_Day_dates(self): - """Test Day's date format..""" + """Test Day's date format.""" with self.assertRaises(HandledException): Day('foo') with self.assertRaises(HandledException): @@ -22,6 +24,51 @@ class DayTests(TestCase): Day('2024-02-01 23:00:00') self.assertEqual(datetime(2024, 1, 1), Day('2024-01-01').datetime) + def test_Day_sorting(self): + """Test Day.__lt__.""" + day1 = Day('2024-01-01') + day2 = Day('2024-01-02') + day3 = Day('2024-01-03') + days = [day3, day1, day2] + self.assertEqual(sorted(days), [day1, day2, day3]) + def test_Day_weekday(self): """Test Day.weekday.""" self.assertEqual(Day('2024-03-17').weekday, 'Sunday') + + def test_Day_by_date(self): + """Test Day.by_date().""" + timestamp = datetime.now().timestamp() + db_file = DatabaseFile(f'test_db:{timestamp}') + db_file.remake() + conn = DatabaseConnection(db_file) + self.assertEqual(None, Day.by_date(conn, '2024-01-01')) + Day('2024-01-01').save(conn) + self.assertEqual(Day('2024-01-01'), Day.by_date(conn, '2024-01-01')) + conn.close() + remove_file(db_file.path) + + def test_Day_all(self): + """Test Day.all(), especially in regards to date range filtering.""" + timestamp = datetime.now().timestamp() + db_file = DatabaseFile(f'test_db:{timestamp}') + db_file.remake() + conn = DatabaseConnection(db_file) + day1 = Day('2024-01-01') + day2 = Day('2024-01-02') + day3 = Day('2024-01-03') + day1.save(conn) + day2.save(conn) + day3.save(conn) + self.assertEqual(Day.all(conn), [day1, day2, day3]) + self.assertEqual(Day.all(conn, ('', '')), [day1, day2, day3]) + self.assertEqual(Day.all(conn, ('2024-01-01', '2024-01-03')), + [day1, day2, day3]) + self.assertEqual(Day.all(conn, ('2024-01-02', '2024-01-03')), + [day2, day3]) + self.assertEqual(Day.all(conn, ('2024-01-03', '')), [day3]) + self.assertEqual(Day.all(conn, ('2024-01-01', '')), [day1, day2, day3]) + self.assertEqual(Day.all(conn, ('', '2024-01-02')), [day1, day2]) + self.assertEqual(Day.all(conn, ('2024-01-03, 2024-01-01')), []) + conn.close() + remove_file(db_file.path)