X-Git-Url: https://wannabe.guru.org/gitweb/?a=blobdiff_plain;f=waitable_presence.py;h=46d7cbe04898c18cd72019c32c4dd1e5545c322e;hb=6e8e3458d9641394b8f061d55ba569a72e6a8493;hp=cd5501da59fc3e3ddd1022f8fd87cfba756aeffc;hpb=36fea7f15ed17150691b5b3ead75450e575229ef;p=python_utils.git diff --git a/waitable_presence.py b/waitable_presence.py index cd5501d..46d7cbe 100644 --- a/waitable_presence.py +++ b/waitable_presence.py @@ -13,16 +13,14 @@ from typing import Optional, Tuple from overrides import overrides import base_presence -from type.locations import Location import site_config import state_tracker +from type.locations import Location logger = logging.getLogger(__name__) -class WaitablePresenceDetectorWithMemory( - state_tracker.WaitableAutomaticStateTracker -): +class WaitablePresenceDetectorWithMemory(state_tracker.WaitableAutomaticStateTracker): """ This is a waitable class that keeps a PresenceDetector internally and periodically polls it to detect changes in presence in a @@ -43,15 +41,17 @@ class WaitablePresenceDetectorWithMemory( self, override_update_interval_sec: float = 60.0, override_location: Location = site_config.get_location(), + injected_presence_detector: Optional[base_presence.PresenceDetection] = None, ) -> None: self.last_someone_is_home: Optional[bool] = None self.someone_is_home: Optional[bool] = None self.everyone_gone_since: Optional[datetime.datetime] = None self.someone_home_since: Optional[datetime.datetime] = None self.location = override_location - self.detector: base_presence.PresenceDetection = ( - base_presence.PresenceDetection() - ) + if injected_presence_detector is not None: + self.detector: base_presence.PresenceDetection = injected_presence_detector + else: + self.detector = base_presence.PresenceDetection() super().__init__( { 'poll_presence': override_update_interval_sec, @@ -88,20 +88,20 @@ class WaitablePresenceDetectorWithMemory( def check_detector(self) -> None: if len(self.detector.dark_locations) > 0: - logger.debug( - 'PresenceDetector is incomplete; trying to reinitialize...' - ) + logger.debug('PresenceDetector is incomplete; trying to reinitialize...') self.detector = base_presence.PresenceDetection() - def is_someone_home(self) -> Tuple[bool, datetime.datetime]: + def is_someone_home(self) -> Optional[Tuple[bool, datetime.datetime]]: """Returns a tuple of a bool that indicates whether someone is home and a datetime that indicates how long either someone has been home or no one has been home. """ if self.someone_is_home is None: - raise Exception("Too Soon!") + return None # checked too soon, wait a bit. if self.someone_is_home: + assert self.someone_home_since is not None return (True, self.someone_home_since) else: + assert self.everyone_gone_since is not None return (False, self.everyone_gone_since)