From c35a6f65f2d9d83fef79a935fd2d10d4db40b4ad Mon Sep 17 00:00:00 2001 From: Laurent Meunier Date: Wed, 25 May 2016 15:54:17 +0200 Subject: [PATCH 1/2] Modify serial nc tests init part During initialization phase of the 2 NC serial tests, there is a character being sent from host to target, based on MBED_HOSTTEST_START. The problem is that the target firmware then creates a "new" serial on the same serial interface. the new or should, or at least may, induce a reset of the IP, so that the character sent by host would be lost. So we're moving the new earlier. the real testing part happens later, to check the next character is not received or sent. --- libraries/tests/mbed/serial_nc_rx/main.cpp | 4 ++-- libraries/tests/mbed/serial_nc_tx/main.cpp | 3 ++- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/libraries/tests/mbed/serial_nc_rx/main.cpp b/libraries/tests/mbed/serial_nc_rx/main.cpp index f97e114378..e5370b4e83 100644 --- a/libraries/tests/mbed/serial_nc_rx/main.cpp +++ b/libraries/tests/mbed/serial_nc_rx/main.cpp @@ -2,13 +2,13 @@ #include "test_env.h" int main() { + Serial *pc = new Serial(USBTX, USBRX); + MBED_HOSTTEST_TIMEOUT(20); MBED_HOSTTEST_SELECT(serial_nc_rx_auto); MBED_HOSTTEST_DESCRIPTION(Serial NC RX); MBED_HOSTTEST_START("MBED_37"); - Serial *pc = new Serial(NC, USBRX); - char c = pc->getc(); delete pc; diff --git a/libraries/tests/mbed/serial_nc_tx/main.cpp b/libraries/tests/mbed/serial_nc_tx/main.cpp index 95e9a311b0..8dae9e50bc 100644 --- a/libraries/tests/mbed/serial_nc_tx/main.cpp +++ b/libraries/tests/mbed/serial_nc_tx/main.cpp @@ -2,13 +2,14 @@ #include "test_env.h" int main() { + Serial *pc = new Serial(USBTX, USBRX); + MBED_HOSTTEST_TIMEOUT(20); MBED_HOSTTEST_SELECT(serial_nc_tx_auto); MBED_HOSTTEST_DESCRIPTION(Serial NC TX); MBED_HOSTTEST_START("MBED_38"); // Wait until we receive start signal from host test - Serial *pc = new Serial(USBTX, USBRX); char c = pc->getc(); delete pc; From 05baf365dcdf109d336fba0fe1911d892c3a25a6 Mon Sep 17 00:00:00 2001 From: Laurent Meunier Date: Thu, 26 May 2016 17:09:30 +0200 Subject: [PATCH 2/2] Synchronize host and target for nc serial auto test We're ensuring target and host start-up sync here in 2 ways: 1) adding a delay on host side to make sure the serial initialization can happen before sending a character is sent to target 2) in case of serial_nc_rx_auto.py test, we're sending a first character S which will trigger the move from rx+tx to NC+rx. This should avoid any crossing case due to HSOT being faster than target or vice-versa --- libraries/tests/mbed/serial_nc_rx/main.cpp | 32 +++++++++++-------- .../host_tests/serial_nc_rx_auto.py | 23 +++++++++++++ .../host_tests/serial_nc_tx_auto.py | 3 ++ 3 files changed, 45 insertions(+), 13 deletions(-) diff --git a/libraries/tests/mbed/serial_nc_rx/main.cpp b/libraries/tests/mbed/serial_nc_rx/main.cpp index e5370b4e83..5f1ebc9dd8 100644 --- a/libraries/tests/mbed/serial_nc_rx/main.cpp +++ b/libraries/tests/mbed/serial_nc_rx/main.cpp @@ -11,22 +11,28 @@ int main() { char c = pc->getc(); - delete pc; - // This should be true - if (c == 'E') { - Serial *pc = new Serial(USBTX, NC); + // This should be true, sync the start of test + if (c == 'S') { + pc->printf("RX OK - Start NC test\r\n"); - pc->printf("RX OK - Expected\r\n"); + // disconnect TX and get char + delete pc; + pc = new Serial(NC, USBRX); + c = pc->getc(); + if (c == 'E') { + // ok disconnect Rx and answer to host + delete pc; + pc = new Serial(USBTX, NC); + pc->printf("RX OK - Expected\r\n"); - c = pc->getc(); - - // This should be false/not get here - if (c == 'U') { - pc->printf("RX OK - Unexpected\r\n"); - } - - delete pc; + c = pc->getc(); + // This should be false/not get here + if (c == 'U') { + pc->printf("RX OK - Unexpected\r\n"); + } + } + delete pc; } while (1) { diff --git a/workspace_tools/host_tests/serial_nc_rx_auto.py b/workspace_tools/host_tests/serial_nc_rx_auto.py index cd12ebe611..59975dbeb7 100644 --- a/workspace_tools/host_tests/serial_nc_rx_auto.py +++ b/workspace_tools/host_tests/serial_nc_rx_auto.py @@ -25,6 +25,29 @@ class SerialNCRXTest(): def test(self, selftest): selftest.mbed.flush(); + # Wait 0.5 seconds to ensure mbed is listening + time.sleep(0.5) + + #handshake with target to sync test start + selftest.mbed.serial_write("S"); + + strip_chars = string.whitespace + "\0" + + out_str = selftest.mbed.serial_readline() + + if not out_str: + selftest.notify("HOST: No output detected") + return selftest.RESULT_IO_SERIAL + + out_str_stripped = out_str.strip(strip_chars) + + if out_str_stripped != "RX OK - Start NC test": + selftest.notify("HOST: Unexpected output. Expected 'RX OK - Expected' but received '%s'" % out_str_stripped) + return selftest.RESULT_FAILURE + + # Wait 0.5 seconds to ensure mbed is listening + time.sleep(0.5) + selftest.mbed.serial_write("E"); strip_chars = string.whitespace + "\0" diff --git a/workspace_tools/host_tests/serial_nc_tx_auto.py b/workspace_tools/host_tests/serial_nc_tx_auto.py index 549bbecb3c..707c4763af 100644 --- a/workspace_tools/host_tests/serial_nc_tx_auto.py +++ b/workspace_tools/host_tests/serial_nc_tx_auto.py @@ -25,6 +25,9 @@ class SerialNCTXTest(): def test(self, selftest): selftest.mbed.flush(); + # Wait 0.5 seconds to ensure mbed is listening + time.sleep(0.5) + selftest.mbed.serial_write("S"); strip_chars = string.whitespace + "\0"