mirror of
https://github.com/infiniteCable2/panda.git
synced 2026-02-18 17:23:52 +08:00
* try 1 * some fixes * fix some misra * first poc working * more things * more misra fixes * fix misra * add rate limiting * fix misra * add some unit tests through libpanda * add more tests and fix some stuff * fix misra again * add startup log hitl test * list * don't fail on wrong timestamps * improvements * fix tests * expected logs test? * not sure why this passed * oh, it doesn't reset * only show last few * guess at expected logs * needs this * ugh * reduce compiler warnings * adjust expected logs * this is correct * is it really 1? * min max * reduce spam in SPI test * some cleanup
89 lines
2.2 KiB
Python
89 lines
2.2 KiB
Python
import os
|
|
import time
|
|
import pytest
|
|
|
|
from panda import Panda, PandaDFU, McuType, BASEDIR
|
|
|
|
|
|
def check_signature(p):
|
|
assert not p.bootstub, "Flashed firmware not booting. Stuck in bootstub."
|
|
assert p.up_to_date()
|
|
|
|
# TODO: make more comprehensive bootstub tests and run on a few production ones + current
|
|
# TODO: also test release-signed app
|
|
@pytest.mark.execution_timeout(30)
|
|
@pytest.mark.expected_logs(1, 2)
|
|
def test_a_known_bootstub(p):
|
|
"""
|
|
Test that compiled app can work with known production bootstub
|
|
"""
|
|
known_bootstubs = {
|
|
# covers the two cases listed in Panda.connect
|
|
McuType.F4: [
|
|
# case A - no bcdDevice or panda type, has to assume F4
|
|
"bootstub_f4_first_dos_production.panda.bin",
|
|
|
|
# case B - just bcdDevice
|
|
"bootstub_f4_only_bcd.panda.bin",
|
|
],
|
|
McuType.H7: ["bootstub.panda_h7.bin"],
|
|
}
|
|
|
|
for kb in known_bootstubs[p.get_mcu_type()]:
|
|
app_ids = (p.get_mcu_type(), p.get_usb_serial())
|
|
assert None not in app_ids
|
|
|
|
p.reset(enter_bootstub=True)
|
|
p.reset(enter_bootloader=True)
|
|
|
|
dfu_serial = p.get_dfu_serial()
|
|
assert Panda.wait_for_dfu(dfu_serial, timeout=30)
|
|
|
|
dfu = PandaDFU(dfu_serial)
|
|
with open(os.path.join(BASEDIR, "tests/hitl/known_bootstub", kb), "rb") as f:
|
|
code = f.read()
|
|
|
|
dfu.program_bootstub(code)
|
|
dfu.reset()
|
|
|
|
p.connect(claim=False, wait=True)
|
|
|
|
# check for MCU or serial mismatch
|
|
with Panda(p._serial, claim=False) as np:
|
|
bootstub_ids = (np.get_mcu_type(), np.get_usb_serial())
|
|
assert app_ids == bootstub_ids
|
|
|
|
# ensure we can flash app and it jumps to app
|
|
p.flash()
|
|
check_signature(p)
|
|
assert not p.bootstub
|
|
|
|
@pytest.mark.execution_timeout(25)
|
|
@pytest.mark.expected_logs(1)
|
|
def test_b_recover(p):
|
|
assert p.recover(timeout=30)
|
|
check_signature(p)
|
|
|
|
@pytest.mark.execution_timeout(25)
|
|
@pytest.mark.expected_logs(3)
|
|
def test_c_flash(p):
|
|
# test flash from bootstub
|
|
serial = p._serial
|
|
assert serial is not None
|
|
p.reset(enter_bootstub=True)
|
|
p.close()
|
|
time.sleep(2)
|
|
|
|
with Panda(serial) as np:
|
|
assert np.bootstub
|
|
assert np._serial == serial
|
|
np.flash()
|
|
|
|
p.reconnect()
|
|
p.reset()
|
|
check_signature(p)
|
|
|
|
# test flash from app
|
|
p.flash()
|
|
check_signature(p)
|