2014-03-17 11:58:35 +00:00
|
|
|
"""
|
|
|
|
mbed SDK
|
|
|
|
Copyright (c) 2011-2013 ARM Limited
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
"""
|
|
|
|
|
|
|
|
import re
|
2014-09-15 16:43:56 +00:00
|
|
|
import random
|
|
|
|
from time import time
|
2014-03-17 11:58:35 +00:00
|
|
|
|
2019-11-21 15:02:37 +00:00
|
|
|
class StdioTest(object):
|
2014-08-15 10:17:33 +00:00
|
|
|
PATTERN_INT_VALUE = "Your value was: (-?\d+)"
|
2014-07-09 10:10:52 +00:00
|
|
|
re_detect_int_value = re.compile(PATTERN_INT_VALUE)
|
2014-03-17 11:58:35 +00:00
|
|
|
|
2015-01-27 12:51:53 +00:00
|
|
|
def test(self, selftest):
|
2014-03-17 11:58:35 +00:00
|
|
|
test_result = True
|
2014-03-17 17:39:24 +00:00
|
|
|
|
2015-01-27 12:51:53 +00:00
|
|
|
c = selftest.mbed.serial_readline() # {{start}} preamble
|
2014-09-03 12:33:23 +00:00
|
|
|
if c is None:
|
2015-01-27 12:51:53 +00:00
|
|
|
return selftest.RESULT_IO_SERIAL
|
|
|
|
selftest.notify(c)
|
2014-09-03 14:01:19 +00:00
|
|
|
|
2014-09-15 10:08:57 +00:00
|
|
|
for i in range(0, 10):
|
2014-09-03 12:33:23 +00:00
|
|
|
random_integer = random.randint(-99999, 99999)
|
2015-01-27 12:51:53 +00:00
|
|
|
selftest.notify("HOST: Generated number: " + str(random_integer))
|
2014-09-22 09:43:21 +00:00
|
|
|
start = time()
|
2015-01-27 12:51:53 +00:00
|
|
|
selftest.mbed.serial_write(str(random_integer) + "\n")
|
2014-03-17 17:39:24 +00:00
|
|
|
|
2015-01-27 12:51:53 +00:00
|
|
|
serial_stdio_msg = selftest.mbed.serial_readline()
|
2014-10-29 10:55:02 +00:00
|
|
|
if serial_stdio_msg is None:
|
2015-01-27 12:51:53 +00:00
|
|
|
return selftest.RESULT_IO_SERIAL
|
2014-09-22 09:43:21 +00:00
|
|
|
delay_time = time() - start
|
2015-01-27 12:51:53 +00:00
|
|
|
selftest.notify(serial_stdio_msg.strip())
|
2014-09-15 10:08:05 +00:00
|
|
|
|
|
|
|
# Searching for reply with scanned values
|
|
|
|
m = self.re_detect_int_value.search(serial_stdio_msg)
|
|
|
|
if m and len(m.groups()):
|
|
|
|
int_value = m.groups()[0]
|
|
|
|
int_value_cmp = random_integer == int(int_value)
|
|
|
|
test_result = test_result and int_value_cmp
|
2015-01-27 12:51:53 +00:00
|
|
|
selftest.notify("HOST: Number %s read after %.3f sec ... [%s]"% (int_value, delay_time, "OK" if int_value_cmp else "FAIL"))
|
2014-03-17 11:58:35 +00:00
|
|
|
else:
|
2014-09-15 10:08:05 +00:00
|
|
|
test_result = False
|
|
|
|
break
|
2015-01-27 12:51:53 +00:00
|
|
|
return selftest.RESULT_SUCCESS if test_result else selftest.RESULT_FAILURE
|