1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/tests/periph_gpio/tests/02-bench.py
Alexandre Abadie bd39ce3179
tests/periph_gpio: increase timeout for automatic test
periph_gpio requires more time to complete on slow platforms, like AVR
2019-11-06 12:46:28 +01:00

41 lines
1.5 KiB
Python
Executable File

#!/usr/bin/env python3
# Copyright (C) 2017 Freie Universität Berlin
#
# This file is subject to the terms and conditions of the GNU Lesser
# General Public License v2.1. See the file LICENSE in the top level
# directory for more details.
import sys
from testrunner import run
# On slow platforms, like AVR, this test can take some time to complete.
TIMEOUT = 30
def testfunc(child):
child.expect_exact("GPIO peripheral driver test")
child.expect_exact(">")
for pin in range(0, 8):
child.sendline("bench 0 {}".format(pin))
child.expect(r" *nop loop: +(\d+)us --- +(\d+\.\d+)us per call --- +(\d+) calls per sec")
child.expect(r" *gpio_set: +(\d+)us --- +(\d+\.\d+)us per call --- +(\d+) calls per sec")
child.expect(r" *gpio_clear: +(\d+)us --- +(\d+\.\d+)us per call --- +(\d+) calls per sec")
child.expect(r" *gpio_toggle: +(\d+)us --- +(\d+\.\d+)us per call --- +(\d+) calls per sec")
child.expect(r" *gpio_read: +(\d+)us --- +(\d+\.\d+)us per call --- +(\d+) calls per sec")
child.expect(r" *gpio_write: +(\d+)us --- +(\d+\.\d+)us per call --- +(\d+) calls per sec")
child.expect_exact(" --- DONE ---")
child.expect_exact(">")
# TODO do some automated verification here? E.g. all pins should have the
# same timing?
# TODO parse output data and put in some unified format?
print("Benchmark was successful")
if __name__ == "__main__":
sys.exit(run(testfunc, timeout=TIMEOUT))