mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 12:52:44 +01:00
Merge pull request #12149 from fjmolinas/pr_suit_test
examples/suit_update: improve test script
This commit is contained in:
commit
e0b7c2d83a
@ -50,7 +50,7 @@ def notify(coap_server, client_url, version=None):
|
|||||||
assert not subprocess.call(cmd)
|
assert not subprocess.call(cmd)
|
||||||
|
|
||||||
|
|
||||||
def publish(server_dir, server_url, app_ver, latest_name=None):
|
def publish(server_dir, server_url, app_ver, keys='default', latest_name=None):
|
||||||
cmd = [
|
cmd = [
|
||||||
"make",
|
"make",
|
||||||
"suit/publish",
|
"suit/publish",
|
||||||
@ -58,6 +58,7 @@ def publish(server_dir, server_url, app_ver, latest_name=None):
|
|||||||
"SUIT_COAP_SERVER={}".format(server_url),
|
"SUIT_COAP_SERVER={}".format(server_url),
|
||||||
"APP_VER={}".format(app_ver),
|
"APP_VER={}".format(app_ver),
|
||||||
"RIOTBOOT_SKIP_COMPILE=1",
|
"RIOTBOOT_SKIP_COMPILE=1",
|
||||||
|
"SUIT_KEY={}".format(keys),
|
||||||
]
|
]
|
||||||
if latest_name is not None:
|
if latest_name is not None:
|
||||||
cmd.append("SUIT_MANIFEST_SIGNED_LATEST={}".format(latest_name))
|
cmd.append("SUIT_MANIFEST_SIGNED_LATEST={}".format(latest_name))
|
||||||
@ -73,6 +74,7 @@ def wait_for_update(child):
|
|||||||
|
|
||||||
|
|
||||||
def get_ipv6_addr(child):
|
def get_ipv6_addr(child):
|
||||||
|
child.expect_exact('>')
|
||||||
child.sendline('ifconfig')
|
child.sendline('ifconfig')
|
||||||
if USE_ETHOS == 0:
|
if USE_ETHOS == 0:
|
||||||
# Get device global address
|
# Get device global address
|
||||||
@ -111,28 +113,45 @@ def ping6(client):
|
|||||||
return ping_ok
|
return ping_ok
|
||||||
|
|
||||||
|
|
||||||
def testfunc(child):
|
def get_reachable_addr(child):
|
||||||
"""For one board test if specified application is updatable"""
|
# Wait for suit_coap thread to start
|
||||||
|
child.expect_exact("suit_coap: started.")
|
||||||
|
child.expect_exact("Starting the shell")
|
||||||
|
# give some time for the network interface to be configured
|
||||||
|
time.sleep(1)
|
||||||
|
# Get address
|
||||||
|
client_addr = get_ipv6_addr(child)
|
||||||
|
# Verify address is reachable
|
||||||
|
ping6(client_addr)
|
||||||
|
return "[{}]".format(client_addr)
|
||||||
|
|
||||||
# Initial Setup and wait for address configuration
|
|
||||||
child.expect_exact("main(): This is RIOT!")
|
|
||||||
|
|
||||||
|
def app_version(child):
|
||||||
# get version of currently running image
|
# get version of currently running image
|
||||||
# "Image Version: 0x00000000"
|
# "Image Version: 0x00000000"
|
||||||
child.expect(r"Image Version: (?P<app_ver>0x[0-9a-fA-F:]+)\r\n")
|
child.expect(r"Image Version: (?P<app_ver>0x[0-9a-fA-F:]+)\r\n")
|
||||||
current_app_ver = int(child.match.group("app_ver"), 16)
|
app_ver = int(child.match.group("app_ver"), 16)
|
||||||
|
return app_ver
|
||||||
|
|
||||||
for version in [current_app_ver + 1, current_app_ver + 2]:
|
|
||||||
child.expect_exact("suit_coap: started.")
|
def _test_invalid_version(child, client, app_ver):
|
||||||
child.expect_exact("Starting the shell")
|
publish(TMPDIR.name, COAP_HOST, app_ver - 1)
|
||||||
# give some time for the network interface to be configured
|
notify(COAP_HOST, client, app_ver - 1)
|
||||||
time.sleep(1)
|
child.expect_exact("suit_coap: trigger received")
|
||||||
# Get address, if using ethos it will change on each reboot
|
child.expect_exact("suit: verifying manifest signature...")
|
||||||
client_addr = get_ipv6_addr(child)
|
child.expect_exact("seq_nr <= running image")
|
||||||
client = "[{}]".format(client_addr)
|
|
||||||
# Wait for suit_coap thread to start
|
|
||||||
# Ping6
|
def _test_invalid_signature(child, client, app_ver):
|
||||||
ping6(client_addr)
|
publish(TMPDIR.name, COAP_HOST, app_ver + 1, 'invalid_keys')
|
||||||
|
notify(COAP_HOST, client, app_ver + 1)
|
||||||
|
child.expect_exact("suit_coap: trigger received")
|
||||||
|
child.expect_exact("suit: verifying manifest signature...")
|
||||||
|
child.expect_exact("Unable to validate signature")
|
||||||
|
|
||||||
|
|
||||||
|
def _test_successful_update(child, client, app_ver):
|
||||||
|
for version in [app_ver + 1, app_ver + 2]:
|
||||||
# Trigger update process, verify it validates manifest correctly
|
# Trigger update process, verify it validates manifest correctly
|
||||||
publish(TMPDIR.name, COAP_HOST, version)
|
publish(TMPDIR.name, COAP_HOST, version)
|
||||||
notify(COAP_HOST, client, version)
|
notify(COAP_HOST, client, version)
|
||||||
@ -150,6 +169,30 @@ def testfunc(child):
|
|||||||
# Verify running slot
|
# Verify running slot
|
||||||
child.expect(r"running from slot (\d+)\r\n")
|
child.expect(r"running from slot (\d+)\r\n")
|
||||||
assert target_slot == int(child.match.group(1)), "BOOTED FROM SAME SLOT"
|
assert target_slot == int(child.match.group(1)), "BOOTED FROM SAME SLOT"
|
||||||
|
# Verify client is reachable and get address
|
||||||
|
client = get_reachable_addr(child)
|
||||||
|
|
||||||
|
|
||||||
|
def testfunc(child):
|
||||||
|
# Get current app_ver
|
||||||
|
current_app_ver = app_version(child)
|
||||||
|
# Verify client is reachable and get address
|
||||||
|
client = get_reachable_addr(child)
|
||||||
|
|
||||||
|
def run(func):
|
||||||
|
if child.logfile == sys.stdout:
|
||||||
|
func(child, client, current_app_ver)
|
||||||
|
else:
|
||||||
|
try:
|
||||||
|
func(child, client, current_app_ver)
|
||||||
|
print(".", end="", flush=True)
|
||||||
|
except Exception as e:
|
||||||
|
print("FAILED")
|
||||||
|
raise e
|
||||||
|
|
||||||
|
run(_test_invalid_signature)
|
||||||
|
run(_test_invalid_version)
|
||||||
|
run(_test_successful_update)
|
||||||
|
|
||||||
print("TEST PASSED")
|
print("TEST PASSED")
|
||||||
|
|
||||||
@ -159,7 +202,6 @@ if __name__ == "__main__":
|
|||||||
res = 1
|
res = 1
|
||||||
aiocoap_process = start_aiocoap_fileserver()
|
aiocoap_process = start_aiocoap_fileserver()
|
||||||
# TODO: wait for coap port to be available
|
# TODO: wait for coap port to be available
|
||||||
|
|
||||||
res = run(testfunc, echo=True)
|
res = run(testfunc, echo=True)
|
||||||
|
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
|
Loading…
Reference in New Issue
Block a user