parent
d66e530573
commit
c3760c267d
1 changed files with 74 additions and 0 deletions
@ -0,0 +1,74 @@ |
|||||||
|
#!/usr/bin/env python3 |
||||||
|
import time |
||||||
|
import unittest |
||||||
|
from parameterized import parameterized |
||||||
|
|
||||||
|
from cereal import log, car |
||||||
|
import cereal.messaging as messaging |
||||||
|
from common.params import Params |
||||||
|
from selfdrive.boardd.boardd_api_impl import can_list_to_can_capnp # pylint: disable=no-name-in-module,import-error |
||||||
|
from selfdrive.car.fingerprints import _FINGERPRINTS |
||||||
|
from selfdrive.car.hyundai.values import CAR as HYUNDAI |
||||||
|
from selfdrive.car.mazda.values import CAR as MAZDA |
||||||
|
from selfdrive.controls.lib.events import EVENT_NAME |
||||||
|
from selfdrive.test.helpers import with_processes |
||||||
|
|
||||||
|
EventName = car.CarEvent.EventName |
||||||
|
|
||||||
|
class TestStartup(unittest.TestCase): |
||||||
|
|
||||||
|
@parameterized.expand([ |
||||||
|
# TODO: test EventName.startup for release branches |
||||||
|
|
||||||
|
# officially supported car |
||||||
|
(EventName.startupMaster, HYUNDAI.SONATA, False), |
||||||
|
(EventName.startupMaster, HYUNDAI.SONATA, True), |
||||||
|
|
||||||
|
# community supported car |
||||||
|
(EventName.startupMaster, HYUNDAI.KIA_STINGER, True), |
||||||
|
(EventName.startupMaster, HYUNDAI.KIA_STINGER, False), |
||||||
|
|
||||||
|
# dashcamOnly car |
||||||
|
(EventName.startupMaster, MAZDA.CX5, True), |
||||||
|
(EventName.startupMaster, MAZDA.CX5, False), |
||||||
|
|
||||||
|
# unrecognized car |
||||||
|
(EventName.startupNoCar, None, True), |
||||||
|
(EventName.startupNoCar, None, False), |
||||||
|
]) |
||||||
|
@with_processes(['controlsd']) |
||||||
|
def test_startup_alert(self, expected_event, car, toggle_enabled): |
||||||
|
|
||||||
|
# TODO: this should be done without any real sockets |
||||||
|
sm = messaging.SubMaster(['controlsState']) |
||||||
|
pm = messaging.PubMaster(['can', 'health']) |
||||||
|
Params().put("CommunityFeaturesToggle", b"1" if toggle_enabled else b"0") |
||||||
|
|
||||||
|
time.sleep(2) # wait for controlsd to be ready |
||||||
|
|
||||||
|
health = messaging.new_message('health') |
||||||
|
health.health.hwType = log.HealthData.HwType.uno |
||||||
|
pm.send('health', health) |
||||||
|
|
||||||
|
# fingerprint |
||||||
|
if car is None: |
||||||
|
finger = {addr: 1 for addr in range(1, 100)} |
||||||
|
else: |
||||||
|
finger = _FINGERPRINTS[car][0] |
||||||
|
|
||||||
|
for _ in range(500): |
||||||
|
msgs = [[addr, 0, b'\x00'*length, 0] for addr, length in finger.items()] |
||||||
|
pm.send('can', can_list_to_can_capnp(msgs)) |
||||||
|
|
||||||
|
time.sleep(0.05) |
||||||
|
sm.update(0) |
||||||
|
if sm.updated["controlsState"]: |
||||||
|
event_name = sm["controlsState"].alertType.split("/")[0] |
||||||
|
self.assertEqual(EVENT_NAME[expected_event], event_name, |
||||||
|
f"expected {EVENT_NAME[expected_event]} for '{car}', got {event_name}") |
||||||
|
break |
||||||
|
else: |
||||||
|
self.fail(f"failed to fingerprint {car}") |
||||||
|
|
||||||
|
if __name__ == "__main__": |
||||||
|
unittest.main() |
Loading…
Reference in new issue