forked from p15670423/monkey
Agent: Add new time_remaining() method to Timer
This commit is contained in:
parent
31fd24f077
commit
e981ead150
|
@ -25,7 +25,18 @@ class Timer:
|
|||
TIMEOUT_SEC, False otherwise
|
||||
:rtype: bool
|
||||
"""
|
||||
return (time.time() - self._start_time) >= self._timeout_sec
|
||||
return self.time_remaining == 0
|
||||
|
||||
@property
|
||||
def time_remaining(self) -> float:
|
||||
"""
|
||||
Return the amount of time remaining until the timer expires.
|
||||
:return: The number of seconds until the timer expires. If the timer is expired, this
|
||||
function returns 0 (it will never return a negative number).
|
||||
:rtype: float
|
||||
"""
|
||||
time_remaining = self._timeout_sec - (time.time() - self._start_time)
|
||||
return time_remaining if time_remaining > 0 else 0
|
||||
|
||||
def reset(self):
|
||||
"""
|
||||
|
|
|
@ -67,3 +67,28 @@ def test_timer_reset(start_time, set_current_time, timeout):
|
|||
|
||||
set_current_time(start_time + (2 * timeout))
|
||||
assert t.is_expired()
|
||||
|
||||
|
||||
def test_time_remaining(start_time, set_current_time):
|
||||
timeout = 5
|
||||
|
||||
t = Timer()
|
||||
t.set(timeout)
|
||||
|
||||
assert t.time_remaining == timeout
|
||||
|
||||
set_current_time(start_time + 2)
|
||||
assert t.time_remaining == 3
|
||||
|
||||
|
||||
def test_time_remaining_is_zero(start_time, set_current_time):
|
||||
timeout = 5
|
||||
|
||||
t = Timer()
|
||||
t.set(timeout)
|
||||
|
||||
set_current_time(start_time + timeout)
|
||||
assert t.time_remaining == 0
|
||||
|
||||
set_current_time(start_time + (2 * timeout))
|
||||
assert t.time_remaining == 0
|
||||
|
|
Loading…
Reference in New Issue