2021-12-29 00:56:42 +01:00
|
|
|
from datetime import timedelta, datetime
|
2021-12-29 02:04:44 +01:00
|
|
|
from .checkin_db import CheckinDB
|
2021-12-29 00:56:42 +01:00
|
|
|
|
|
|
|
TEST_DB_NAME = "test.db"
|
|
|
|
|
|
|
|
checkin_db = CheckinDB(TEST_DB_NAME)
|
|
|
|
checkin_db.clear_rows()
|
|
|
|
|
|
|
|
|
|
|
|
def test_get_present_count() -> None:
|
|
|
|
checkin_db.update("Alice", True)
|
|
|
|
checkin_db.update("Bob", True)
|
|
|
|
checkin_db.update("Bob", False)
|
|
|
|
checkin_db.update("Bob", True)
|
|
|
|
assert checkin_db.get_checkin_count() == 2
|
|
|
|
|
|
|
|
|
|
|
|
def test_present_names() -> None:
|
|
|
|
assert checkin_db.get_checkin_names() == ["Alice", "Bob"]
|
|
|
|
|
|
|
|
|
|
|
|
def test_updated_timestamp() -> None:
|
|
|
|
assert checkin_db.get_updated_for_name(
|
|
|
|
"Alice"
|
|
|
|
) >= datetime.now() - timedelta(minutes=1)
|
|
|
|
|
|
|
|
|
|
|
|
def test_auto_checkout() -> None:
|
|
|
|
assert "Alice" in checkin_db.get_checkin_names()
|
|
|
|
old_timestamp = (datetime.now() - timedelta(hours=6)).timestamp()
|
|
|
|
with checkin_db.con:
|
|
|
|
checkin_db.con.execute(
|
|
|
|
f"UPDATE checkin SET updated = {old_timestamp} WHERE name = 'Alice'"
|
|
|
|
)
|
|
|
|
checkin_db.auto_checkout()
|
|
|
|
assert "Alice" not in checkin_db.get_checkin_names()
|