from test.helpers.syscmd import SysCommand import unittest import uuid import serial import time class Qduplex(unittest.TestCase): def __init__(self, testname, testfunc, varlist): super(Qduplex, self).__init__(testfunc) if "port1" in varlist: self.__port1 = varlist["port1"] else: raise Exception('port1 param inside Qduplex must be defined') self.__serial1 = serial.Serial(self.__port1, timeout=1) if "port2" in varlist: self.__port2 = varlist["port2"] else: raise Exception('port2 param inside Qduplex must be defined') self.__serial2 = serial.Serial(self.__port2, timeout=1) if "baudrate" in varlist: self.__serial1.baudrate = varlist["baudrate"] self.__serial2.baudrate = varlist["baudrate"] else: raise Exception('baudrate param inside Qduplex must be defined') self._testMethodDoc = testname def __del__(self): self.__serial1.close() self.__serial2.close() def execute(self): self.__serial1.flushInput() self.__serial1.flushOutput() self.__serial2.flushInput() self.__serial2.flushOutput() test_uuid = str(uuid.uuid4()).encode() self.__serial1.write(test_uuid) time.sleep(0.05) # there might be a small delay if self.__serial2.inWaiting() == 0: self.fail("failed: PORT {} wait timeout exceded, wrong communication?".format(self.__port2)) else: if (self.__serial2.readline() != test_uuid): self.fail("failed: PORT {} write/read mismatch".format(self.__port2)) test_uuid = str(uuid.uuid4()).encode() self.__serial2.write(test_uuid) time.sleep(0.05) # there might be a small delay if self.__serial1.inWaiting() == 0: self.fail("failed: PORT {} wait timeout exceded, wrong communication?".format(self.__port1)) else: if (self.__serial1.readline() != test_uuid): self.fail("failed: PORT {} write/read mismatch".format(self.__port1))