|
@@ -1,4 +1,5 @@
|
|
|
import io
|
|
|
+import logging
|
|
|
import pathlib
|
|
|
import subprocess
|
|
|
import unittest.mock
|
|
@@ -14,19 +15,149 @@ def test_entrypoint_help():
|
|
|
subprocess.run(["ics2vdir", "--help"], check=True, stdout=subprocess.PIPE)
|
|
|
|
|
|
|
|
|
-def test__main_create(
|
|
|
- temp_dir_path: pathlib.Path, google_calendar_file: io.BufferedReader
|
|
|
+def test__main_create_all(
|
|
|
+ caplog, temp_dir_path: pathlib.Path, google_calendar_file: io.BufferedReader
|
|
|
):
|
|
|
with unittest.mock.patch("sys.stdin", google_calendar_file):
|
|
|
with unittest.mock.patch("sys.argv", ["", "--output-dir", str(temp_dir_path)]):
|
|
|
- ics2vdir._main()
|
|
|
+ with caplog.at_level(logging.INFO):
|
|
|
+ ics2vdir._main()
|
|
|
created_item_paths = sorted(temp_dir_path.iterdir())
|
|
|
assert [p.name for p in created_item_paths] == [
|
|
|
"1234567890qwertyuiopasdfgh@google.com.ics",
|
|
|
"recurr1234567890qwertyuiop@google.com.20150908T090000+0200.ics",
|
|
|
"recurr1234567890qwertyuiop@google.com.20150924T090000+0200.ics",
|
|
|
]
|
|
|
+ assert len(caplog.records) == len(created_item_paths)
|
|
|
+ for item_path in created_item_paths:
|
|
|
+ assert any(
|
|
|
+ item_path.name in record.message and "creating" in record.message
|
|
|
+ for record in caplog.records
|
|
|
+ )
|
|
|
event = icalendar.cal.Event.from_ical(created_item_paths[1].read_bytes())
|
|
|
assert isinstance(event, icalendar.cal.Event)
|
|
|
assert event["UID"] == "recurr1234567890qwertyuiop@google.com"
|
|
|
assert event["SUMMARY"] == "recurring"
|
|
|
+
|
|
|
+
|
|
|
+def test__main_create_some(
|
|
|
+ caplog, temp_dir_path: pathlib.Path, google_calendar_file: io.BufferedReader
|
|
|
+):
|
|
|
+ with unittest.mock.patch("sys.stdin", google_calendar_file):
|
|
|
+ with unittest.mock.patch("sys.argv", ["", "--output-dir", str(temp_dir_path)]):
|
|
|
+ ics2vdir._main()
|
|
|
+ temp_dir_path.joinpath(
|
|
|
+ "recurr1234567890qwertyuiop@google.com.20150924T090000+0200.ics"
|
|
|
+ ).unlink()
|
|
|
+ google_calendar_file.seek(0)
|
|
|
+ with caplog.at_level(logging.INFO):
|
|
|
+ ics2vdir._main()
|
|
|
+ assert len(caplog.records) == 1
|
|
|
+ assert caplog.records[0].message.startswith("creating")
|
|
|
+ assert caplog.records[0].message.endswith(
|
|
|
+ "recurr1234567890qwertyuiop@google.com.20150924T090000+0200.ics"
|
|
|
+ )
|
|
|
+
|
|
|
+
|
|
|
+def test__main_update(
|
|
|
+ caplog, temp_dir_path: pathlib.Path, google_calendar_file: io.BufferedReader
|
|
|
+):
|
|
|
+ with unittest.mock.patch("sys.stdin", google_calendar_file):
|
|
|
+ with unittest.mock.patch("sys.argv", ["", "--output-dir", str(temp_dir_path)]):
|
|
|
+ ics2vdir._main()
|
|
|
+ temp_dir_path.joinpath(
|
|
|
+ "recurr1234567890qwertyuiop@google.com.20150924T090000+0200.ics"
|
|
|
+ ).unlink()
|
|
|
+ updated_path = temp_dir_path.joinpath(
|
|
|
+ "recurr1234567890qwertyuiop@google.com.20150908T090000+0200.ics"
|
|
|
+ )
|
|
|
+ updated_ical = updated_path.read_bytes().replace(b"20150908", b"20140703")
|
|
|
+ with updated_path.open("wb") as updated_file:
|
|
|
+ updated_file.write(updated_ical)
|
|
|
+ google_calendar_file.seek(0)
|
|
|
+ with caplog.at_level(logging.INFO):
|
|
|
+ ics2vdir._main()
|
|
|
+ assert len(caplog.records) == 2
|
|
|
+ log_records = sorted(caplog.records, key=lambda r: r.message)
|
|
|
+ assert log_records[0].message.startswith("creating")
|
|
|
+ assert log_records[0].message.endswith(
|
|
|
+ "recurr1234567890qwertyuiop@google.com.20150924T090000+0200.ics"
|
|
|
+ )
|
|
|
+ assert log_records[1].message.startswith("updating")
|
|
|
+ assert log_records[1].message.endswith(
|
|
|
+ "recurr1234567890qwertyuiop@google.com.20150908T090000+0200.ics"
|
|
|
+ )
|
|
|
+
|
|
|
+
|
|
|
+def test__main_update_silent(
|
|
|
+ caplog, temp_dir_path: pathlib.Path, google_calendar_file: io.BufferedReader
|
|
|
+):
|
|
|
+ with unittest.mock.patch("sys.stdin", google_calendar_file):
|
|
|
+ with unittest.mock.patch(
|
|
|
+ "sys.argv", ["", "--output-dir", str(temp_dir_path), "--silent"]
|
|
|
+ ):
|
|
|
+ ics2vdir._main()
|
|
|
+ temp_dir_path.joinpath(
|
|
|
+ "recurr1234567890qwertyuiop@google.com.20150924T090000+0200.ics"
|
|
|
+ ).unlink()
|
|
|
+ updated_path = temp_dir_path.joinpath(
|
|
|
+ "recurr1234567890qwertyuiop@google.com.20150908T090000+0200.ics"
|
|
|
+ )
|
|
|
+ updated_ical = updated_path.read_bytes().replace(b"20150908", b"20140703")
|
|
|
+ with updated_path.open("wb") as updated_file:
|
|
|
+ updated_file.write(updated_ical)
|
|
|
+ google_calendar_file.seek(0)
|
|
|
+ with caplog.at_level(logging.INFO):
|
|
|
+ ics2vdir._main()
|
|
|
+ assert len(caplog.records) == 0
|
|
|
+
|
|
|
+
|
|
|
+def test__main_update_verbose(
|
|
|
+ caplog, temp_dir_path: pathlib.Path, google_calendar_file: io.BufferedReader
|
|
|
+):
|
|
|
+ with unittest.mock.patch("sys.stdin", google_calendar_file):
|
|
|
+ with unittest.mock.patch(
|
|
|
+ "sys.argv", ["", "--output-dir", str(temp_dir_path), "--verbose"]
|
|
|
+ ):
|
|
|
+ ics2vdir._main()
|
|
|
+ temp_dir_path.joinpath(
|
|
|
+ "recurr1234567890qwertyuiop@google.com.20150924T090000+0200.ics"
|
|
|
+ ).unlink()
|
|
|
+ updated_path = temp_dir_path.joinpath(
|
|
|
+ "recurr1234567890qwertyuiop@google.com.20150908T090000+0200.ics"
|
|
|
+ )
|
|
|
+ updated_ical = updated_path.read_bytes().replace(b"20150908", b"20140703")
|
|
|
+ with updated_path.open("wb") as updated_file:
|
|
|
+ updated_file.write(updated_ical)
|
|
|
+ google_calendar_file.seek(0)
|
|
|
+ ics2vdir._main()
|
|
|
+ assert any(
|
|
|
+ r.message.endswith("1234567890qwertyuiopasdfgh@google.com.ics is up to date")
|
|
|
+ for r in caplog.records
|
|
|
+ )
|
|
|
+ assert any(
|
|
|
+ r.message.startswith("creating")
|
|
|
+ and r.message.endswith(".20150924T090000+0200.ics")
|
|
|
+ for r in caplog.records
|
|
|
+ )
|
|
|
+ assert any(
|
|
|
+ r.message.startswith("updating")
|
|
|
+ and r.message.endswith(".20150908T090000+0200.ics")
|
|
|
+ for r in caplog.records
|
|
|
+ )
|
|
|
+
|
|
|
+
|
|
|
+def test__main_delete(
|
|
|
+ caplog, temp_dir_path: pathlib.Path, google_calendar_file: io.BufferedReader
|
|
|
+):
|
|
|
+ temp_dir_path.joinpath("will-be-deleted.ics").touch()
|
|
|
+ with unittest.mock.patch("sys.stdin", google_calendar_file):
|
|
|
+ with unittest.mock.patch(
|
|
|
+ "sys.argv", ["", "--output-dir", str(temp_dir_path), "--delete"]
|
|
|
+ ):
|
|
|
+ with caplog.at_level(logging.INFO):
|
|
|
+ ics2vdir._main()
|
|
|
+ assert len(list(temp_dir_path.iterdir())) == 3
|
|
|
+ assert not any(p.name == "will-be-deleted.ics" for p in temp_dir_path.iterdir())
|
|
|
+ assert caplog.records[-1].message.startswith("removing")
|
|
|
+ assert caplog.records[-1].message.endswith("will-be-deleted.ics")
|