Skip to content

Commit

Permalink
clean up test
Browse files Browse the repository at this point in the history
  • Loading branch information
sshane committed Oct 4, 2024
1 parent 4338b33 commit e7c0f80
Showing 1 changed file with 20 additions and 27 deletions.
47 changes: 20 additions & 27 deletions selfdrive/selfdrived/tests/test_alertmanager.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,55 +11,48 @@ def test_duration(self):
Enforce that an alert lasts for max(alert duration, duration the alert is added)
"""
for duration in range(1, 100):
print('duration', duration)
alert = None
while not isinstance(alert, Alert):
event = random.choice([e for e in EVENTS.values() if len(e)])
alert = random.choice(list(event.values()))

alert.duration = duration

# check two cases:
# - alert is added to AM for <= the alert's duration
# - alert is added to AM for > alert's duration
for greater in (True, False):
if greater:
add_duration = duration + random.randint(1, 10)
else:
add_duration = random.randint(1, duration)
show_duration = max(duration, add_duration)

AM = AlertManager()
for frame in range(duration+10):
if frame < add_duration:
AM.add_many(frame, [alert, ])
AM.process_alerts(frame, set())

shown = AM.current_alert != EmptyAlert
should_show = frame <= show_duration
assert shown == should_show, f"{frame=} {add_duration=} {duration=}"

# check one case:
# - if alert is re-added to AM before it ends the duration is extended
if duration > 1:
AM = AlertManager()
show_duration = duration * 2
for frame in range(duration * 2 + 10):
print(frame)
if frame == 0:
AM.add_many(frame, [alert, ])
print('added!')

if frame == duration:
# add alert one frame before it ends
assert AM.current_alert == alert
AM.add_many(frame, [alert, ])
print('added!')
AM.process_alerts(frame, set())
print('alert', AM.current_alert)

shown = AM.current_alert != EmptyAlert
should_show = frame <= show_duration
print('shown', shown, 'should_show', should_show)
print()
assert shown == should_show, f"{frame=} {duration=}"

# # check two cases:
# # - alert is added to AM for <= the alert's duration
# # - alert is added to AM for > alert's duration
# for greater in (True, False):
# if greater:
# add_duration = duration + random.randint(1, 10)
# else:
# add_duration = random.randint(1, duration)
# show_duration = max(duration, add_duration)
#
# AM = AlertManager()
# for frame in range(duration+10):
# if frame < add_duration:
# AM.add_many(frame, [alert, ])
# AM.process_alerts(frame, set())
#
# shown = AM.current_alert != EmptyAlert
# should_show = frame <= show_duration
# assert shown == should_show, f"{frame=} {add_duration=} {duration=}"

0 comments on commit e7c0f80

Please sign in to comment.