2018-11-19 16:46:45 +01:00
|
|
|
# Copyright (C) 2018-19 Freie Universität Berlin
|
|
|
|
# 2017 Cenk Gündoğan <cenk.guendogan@haw-hamburg.de>
|
2017-11-12 13:00:08 +01:00
|
|
|
# 2016 Kaspar Schleiser <kaspar@schleiser.de>
|
2016-03-05 15:59:35 +01:00
|
|
|
# 2014 Martine Lenders <mlenders@inf.fu-berlin.de>
|
|
|
|
#
|
|
|
|
# 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.
|
|
|
|
|
2017-11-10 13:22:26 +01:00
|
|
|
import os
|
|
|
|
import sys
|
2020-03-12 13:42:35 +01:00
|
|
|
from functools import partial
|
2018-11-19 16:46:45 +01:00
|
|
|
from traceback import print_tb
|
2017-10-25 15:24:25 +02:00
|
|
|
import pexpect
|
2017-11-10 13:22:26 +01:00
|
|
|
|
2018-11-19 16:46:45 +01:00
|
|
|
from .spawn import find_exc_origin, setup_child, teardown_child
|
2019-01-22 10:30:55 +01:00
|
|
|
from .unittest import PexpectTestCase # noqa, F401 expose to users
|
2019-03-23 14:46:37 +01:00
|
|
|
from .utils import test_utils_interactive_sync # noqa, F401 expose to users
|
2017-11-12 12:59:45 +01:00
|
|
|
|
2019-07-16 18:28:46 +02:00
|
|
|
# Timeout for tests can be changed by setting RIOT_TEST_TIMEOUT to the desired
|
|
|
|
# value in the environment variables
|
|
|
|
# default value (10)
|
|
|
|
TIMEOUT = int(os.environ.get('RIOT_TEST_TIMEOUT') or 10)
|
2017-12-20 13:34:52 +01:00
|
|
|
|
2019-07-16 18:28:46 +02:00
|
|
|
|
|
|
|
def run(testfunc, timeout=TIMEOUT, echo=True, traceback=False):
|
2018-11-19 16:46:45 +01:00
|
|
|
child = setup_child(timeout, env=os.environ,
|
|
|
|
logfile=sys.stdout if echo else None)
|
2016-03-05 15:59:35 +01:00
|
|
|
try:
|
|
|
|
testfunc(child)
|
2017-10-25 15:24:25 +02:00
|
|
|
except pexpect.TIMEOUT:
|
2017-11-30 10:02:58 +01:00
|
|
|
trace = find_exc_origin(sys.exc_info()[2])
|
|
|
|
print("Timeout in expect script at \"%s\" (%s:%d)" % trace)
|
2016-04-08 22:39:49 +02:00
|
|
|
if traceback:
|
|
|
|
print_tb(sys.exc_info()[2])
|
2016-03-05 15:59:35 +01:00
|
|
|
return 1
|
2017-11-12 13:00:08 +01:00
|
|
|
except pexpect.EOF:
|
2017-11-30 10:02:58 +01:00
|
|
|
trace = find_exc_origin(sys.exc_info()[2])
|
2018-11-19 16:46:45 +01:00
|
|
|
print("Unexpected end of file in expect script at \"%s\" (%s:%d)" %
|
|
|
|
trace)
|
2017-11-12 13:00:08 +01:00
|
|
|
if traceback:
|
|
|
|
print_tb(sys.exc_info()[2])
|
|
|
|
return 1
|
2016-03-05 15:59:35 +01:00
|
|
|
finally:
|
|
|
|
print("")
|
2018-11-19 16:46:45 +01:00
|
|
|
teardown_child(child)
|
2016-03-05 15:59:35 +01:00
|
|
|
return 0
|
2020-03-12 13:42:35 +01:00
|
|
|
|
|
|
|
|
|
|
|
def check_unittests(child, timeout=TIMEOUT, nb_tests=None):
|
2020-03-20 11:24:48 +01:00
|
|
|
""" Check the number of unit tests that passed, and return the amount.
|
|
|
|
|
|
|
|
If the amount of expected tests to pass is known, nd_tests can be set
|
|
|
|
to perform an exact match against that number.
|
|
|
|
"""
|
|
|
|
if nb_tests is None:
|
|
|
|
child.expect(r'OK \((\d+) tests\)', timeout=timeout)
|
|
|
|
return int(child.match.group(1))
|
|
|
|
_tests = int(nb_tests)
|
|
|
|
child.expect_exact('OK ({} tests)'.format(_tests), timeout=timeout)
|
|
|
|
return _tests
|
2020-03-12 13:42:35 +01:00
|
|
|
|
|
|
|
|
|
|
|
def run_check_unittests(timeout=TIMEOUT, echo=True, traceback=False,
|
|
|
|
nb_tests=None):
|
|
|
|
_unittests_func = partial(check_unittests,
|
|
|
|
timeout=timeout, nb_tests=nb_tests)
|
|
|
|
|
|
|
|
return run(_unittests_func, timeout, echo, traceback)
|